Prototype 學(xué)習(xí) 工具函數(shù)學(xué)習(xí)($方法)
更新時間:2009年07月12日 22:03:12 作者:
$方法——被成為瑞士軍刀$方法使用技巧。
$
$$
$A
$F
$H
$R
$w
Try.these
document.getElementsByClassName
$方法——被成為瑞士軍刀(Swiss Army knife)
If provided with a string, returns the element in the document with matching ID; otherwise returns the passed element. Takes in an arbitrary number of arguments. All elements returned by the function are extended with Prototype DOM extensions.
function $(element) {
if (arguments.length > 1) {
for (var i = 0, elements = [], length = arguments.length; i < length;
i++)
elements.push($(arguments[i]));
return elements;
}
if (Object.isString(element))
element = document.getElementById(element);
return Element.extend(element);
}
首先檢查傳進(jìn)來的參數(shù)長度:
如果長度等于1,則判斷傳進(jìn)來的參數(shù)是否為String,如果傳進(jìn)來的是String,則調(diào)用getElementById方法取得相應(yīng)的對象,最后讓返回的對象繼承Element的所有方法,這樣返回的對象將可以直接調(diào)用Element對象里面定義的各種方法。例如
// Note quite OOP-like...
Element.hide('itemId');
// A cleaner feel, thanks to guaranted extension
$('itemId').hide();
如果長度大于1,則遞歸調(diào)用$方法(elements.push($(arguments[i]));)就是說傳進(jìn)來的參數(shù)可以是多維數(shù)組:
$(['A','B',['C','D',['E','F']]]),當(dāng)然了返回的也是對象數(shù)組了。
如果長度等于0,返回undefined,即直接調(diào)用alert($())
詳細(xì)看一下Object.isString方法:
function isString(object) {
return getClass(object) === "String";
}
//=====> getClass()
function getClass(object) {
return Object.prototype.toString.call(object)
.match(/^\[object\s(.*)\]$/)[1];
}
主要是通過Object對象的內(nèi)部方法getClass來確定返回的對象是什么類型,在getClass中調(diào)用了Object的toString方法,然后通過正則表達(dá)式取出表示具體對象的字符串
Object.prototype.toString.call("2222") 返回"[object String]" 取得"String"
Object.prototype.toString.call(2222) 返回"[object Number]" 取得"Number"
Object.prototype.toString.call(/^$/) 返回"[object RegExp]" 取得"RegExp"
這里為什么要用Object的toString方法呢,因為如果直接調(diào)用"2222".toString()將返回"2222",也就是說從Object繼承而來的對象,重寫了toStirng方法,所以這里要調(diào)用Object的toString才行。
$$
$A
$F
$H
$R
$w
Try.these
document.getElementsByClassName
$方法——被成為瑞士軍刀(Swiss Army knife)
If provided with a string, returns the element in the document with matching ID; otherwise returns the passed element. Takes in an arbitrary number of arguments. All elements returned by the function are extended with Prototype DOM extensions.
復(fù)制代碼 代碼如下:
function $(element) {
if (arguments.length > 1) {
for (var i = 0, elements = [], length = arguments.length; i < length;
i++)
elements.push($(arguments[i]));
return elements;
}
if (Object.isString(element))
element = document.getElementById(element);
return Element.extend(element);
}
首先檢查傳進(jìn)來的參數(shù)長度:
如果長度等于1,則判斷傳進(jìn)來的參數(shù)是否為String,如果傳進(jìn)來的是String,則調(diào)用getElementById方法取得相應(yīng)的對象,最后讓返回的對象繼承Element的所有方法,這樣返回的對象將可以直接調(diào)用Element對象里面定義的各種方法。例如
復(fù)制代碼 代碼如下:
// Note quite OOP-like...
Element.hide('itemId');
// A cleaner feel, thanks to guaranted extension
$('itemId').hide();
如果長度大于1,則遞歸調(diào)用$方法(elements.push($(arguments[i]));)就是說傳進(jìn)來的參數(shù)可以是多維數(shù)組:
$(['A','B',['C','D',['E','F']]]),當(dāng)然了返回的也是對象數(shù)組了。
如果長度等于0,返回undefined,即直接調(diào)用alert($())
詳細(xì)看一下Object.isString方法:
復(fù)制代碼 代碼如下:
function isString(object) {
return getClass(object) === "String";
}
//=====> getClass()
function getClass(object) {
return Object.prototype.toString.call(object)
.match(/^\[object\s(.*)\]$/)[1];
}
主要是通過Object對象的內(nèi)部方法getClass來確定返回的對象是什么類型,在getClass中調(diào)用了Object的toString方法,然后通過正則表達(dá)式取出表示具體對象的字符串
Object.prototype.toString.call("2222") 返回"[object String]" 取得"String"
Object.prototype.toString.call(2222) 返回"[object Number]" 取得"Number"
Object.prototype.toString.call(/^$/) 返回"[object RegExp]" 取得"RegExp"
這里為什么要用Object的toString方法呢,因為如果直接調(diào)用"2222".toString()將返回"2222",也就是說從Object繼承而來的對象,重寫了toStirng方法,所以這里要調(diào)用Object的toString才行。
相關(guān)文章
Prototype的Class.create函數(shù)解析
Prototype中的類的創(chuàng)建,一般使用Class.create方法來創(chuàng)建,例如PeriodicalExecuter類型。使用的時候通過調(diào)用new PeriodicalExecuter(xxx)來生成對象。2011-09-09prototype 源碼中文說明之 prototype.js
prototype 源碼中文說明之 prototype.js...2006-09-09Prototype源碼淺析 String部分(三)之HTML字符串處理
現(xiàn)在,String部分轉(zhuǎn)入具體的關(guān)聯(lián)應(yīng)用,分別對應(yīng)HTML字符串,JSON字符串和HTML中的腳本字符串2012-01-01