yunshichen

我相信人生是值得活的,尽管人在一生中必须遭受痛苦,卑劣,残酷,不幸和死亡的折磨,我依然深信如此.但我认为人生不一定要有意义,只是对一些人而言,他们可以使人生有意义. ---J 赫胥黎

YUI 第一篇 : Yahoo global object 翻译


简介

Yahoo global object 提供namespace机制和封装了一些好用的方法. js名称为yahoo.js ,使用YUI前必须先引入这个js,且应该最先加载.

源文件
<script type="text/javascript" src="http://yui.yahooapis.com/2.6.0/build/yahoo/yahoo-min.js" ></script>

常用方法列举如下:

YAHOO.namespace


避免js全局变量污染的好办法,用法如下:
// Creates a namespace for "myproduct1"
YAHOO.namespace ("myproduct1");
YAHOO.myproduct1.Class1 
= function(info) {
    alert(info);
};

// Creates a namespace for "myproduct2", and for "mysubproject1"
YAHOO.namespace ("myproduct2.mysubproject1");
YAHOO.myproduct2.mysubproject1.Class1 
= function(info) {
    alert(info);
};

YAHOO.lang


提供了一些简便易用方法,如下:

// true, an array literal is an array
YAHOO.lang.isArray([12]);

// false, an object literal is not an array
YAHOO.lang.isArray({"one""two"});

// however, when declared as an array, it is true
function() {
    
var a = new Array();
    a[
"one"= "two";
    
return YAHOO.lang.isArray(a);
}();

// false, a collection of elements is like an array, but isn't
YAHOO.lang.isArray(document.getElementsByTagName("body"));

// true, false is a boolean
YAHOO.lang.isBoolean(false);

// false, 1 and the string "true" are not booleans
YAHOO.lang.isBoolean(1);
YAHOO.lang.isBoolean(
"true");

// null is null, but false, undefined and "" are not
YAHOO.lang.isNull(null); // true
YAHOO.lang.isNull(undefined); // false
YAHOO.lang.isNull(""); // false

// a function is a function, but an object is not
YAHOO.lang.isFunction(function(){}); // true
YAHOO.lang.isFunction({foo: "bar"}); // false

// true, ints and floats are numbers
YAHOO.lang.isNumber(0);
YAHOO.lang.isNumber(
123.123);

// false, strings that can be cast to numbers aren't really numbers
YAHOO.lang.isNumber("123.123");

// false, undefined numbers and infinity are not numbers we want to use
YAHOO.lang.isNumber(1/0);

// true, objects, functions, and arrays are objects
YAHOO.lang.isObject({});
YAHOO.lang.isObject(
function(){});
YAHOO.lang.isObject([
1,2]);

// false, primitives are not objects
YAHOO.lang.isObject(1);
YAHOO.lang.isObject(
true);
YAHOO.lang.isObject(
"{}");

// strings
YAHOO.lang.isString("{}"); // true
YAHOO.lang.isString({foo: "bar"}); // false
YAHOO.lang.isString(123); // false
YAHOO.lang.isString(true); // false
 
// undefined is undefined, but null and false are not
YAHOO.lang.isUndefined(undefined); // true
YAHOO.lang.isUndefined(false); // false
YAHOO.lang.isUndefined(null); // false


YAHOO.lang.hasOwnProperty

检查某个对象是否有某属性

// this is what we are protecting against
Object.prototype.myCustomFunction = function(x) {
    alert(x);
}

var o = {};
o[
"foo"= "bar";
o[
"marco"= "polo";

// this is where we need the protection
for (var i in o) {
    
if (YAHOO.lang.hasOwnProperty(o, i)) {
        alert(
"good key: " + i);
    } 
else {
        alert(
"bad key: " + i);
    }
}

YAHOO.lang.extend

提供了继承机制.(译者注:js使用继承还是有一定风险,建议酌情使用.)

YAHOO.namespace("test");

YAHOO.test.Class1 
= function(info) {
    alert(
"Class1: " + info);
};

YAHOO.test.Class1.prototype.testMethod 
= function(info) {
    alert(
"Class1: " + info);
};

YAHOO.test.Class2 
= function(info) {
    
// chain the constructors
    YAHOO.test.Class2.superclass.constructor.call(this, info);
    alert(
"Class2: " + info);
};

// Class2 extends Class1.  Must be done immediately after the Class2 constructor
YAHOO.lang.extend(YAHOO.test.Class2, YAHOO.test.Class1);

YAHOO.test.Class2.prototype.testMethod 
= function(info) {
    
// chain the method
    YAHOO.test.Class2.superclass.testMethod.call(this, info);
    alert(
"Class2: " + info);
};

var class2Instance = new YAHOO.test.Class2("constructor executed");
class2Instance.testMethod(
"testMethod invoked");


YAHOO.lang.augment

将某个对象的prototype属性复制到另一个对象,代码重用的好方法.
<!-- debugger output for environments without "console" -->
<div id="consoleelement"> </div>

<script>
////////////////////////////////////////////////////////////////////////////
//
 The ConsoleProvider example will log to the console if available, or a 
//
 div with id="consoleelement" if the console is not available
//
//////////////////////////////////////////////////////////////////////////
YAHOO.example.ConsoleProvider = function() { };
YAHOO.example.ConsoleProvider.prototype 
= {
    log: 
function(msg) {
        
// use the error console if available (FF+FireBug or Safari)
        if (typeof console != "undefined") {
            console.log(msg);
        
// write the msg to a well-known div element
        } else {
            
var el = document.getElementById("consoleelement");
            
if (el) {
                el.innerHTML 
+= "<p>" + msg + "</p>";
            }
        }
    }
};

////////////////////////////////////////////////////////////////////////////
//
 Define a class that should be able to write debug messages
//
//////////////////////////////////////////////////////////////////////////
YAHOO.example.ClassWithLogging = function() { };
YAHOO.lang.augment(YAHOO.example.ClassWithLogging, YAHOO.example.ConsoleProvider);

////////////////////////////////////////////////////////////////////////////
//
 Try it out
//
//////////////////////////////////////////////////////////////////////////
var c = new YAHOO.example.ClassWithLogging();
c.log(
"worked");

</script>

YAHOO.log

log工具,使用之前要先引入logger控件,如果没有引入,那么浏览器会忽略这条log语句.用这个东西使你免陷于开发时加alert,发布时四处删除alert的窘境.(注:当然,用firebug调试也可以避免alert问题.).


其他

至于YAHOO.env 和 YAHOO.name 等,参考官方文档即可.

http://developer.yahoo.com/yui/yahoo/




posted on 2008-10-09 17:25 Chenyunshi 阅读(1008) 评论(3)  编辑 收藏 引用 所属分类: Yahoo YUI

只有注册用户登录后才能发表评论。
<2009年4月>
2930311234
567891011
12131415161718
19202122232425
262728293012
3456789

导航

统计

常用链接

留言簿(7)

随笔分类

随笔档案

文章分类

相册

搜索

最新评论

阅读排行榜

评论排行榜