YUI 讀碼日記之 YAHOO.util.Dom - Part.1
更新時間:2008年03月22日 14:40:47 作者:
DOM 操作是學習 Javascript 很重點的一塊。YUI 提供了豐富的 DOM 操作接口,它們定義在 %BUILD%/dom/dom.js 中(封裝成 YAHOO.util.Dom)。由于 DOM 操作比較重要,我計劃將其分成幾個 Part 分析。
先繞開頭部很多的 if...else (其實就是定義 toCamel 與 getStyle 兩個函數(shù)) - 由于瀏覽器的實現(xiàn)不統(tǒng)一,才造成如此麻煩的情況,回頭可以聊聊這些代碼。
下面我們在 YAHOO.util.Dom 類中看看有哪些寶藏。目前思想已經(jīng)逐步的分裂,我看見個函數(shù)說個函數(shù)。
// 基本上可以認為是 document.getElementById 的翻版
get: function(el) {
// 如果已經(jīng)是 HTMLElement ,那么就直接返回
if (el && (el.nodeType || el.item)) {
return el;
}
// 如果是字符串,那么就返回有這個 ID 的 Element
if (YAHOO.lang.isString(el) || !el) {
return document.getElementById(el);
}
// 看起來是個數(shù)組,循環(huán)調用自身,獲取 Eelement
if (el.length !== undefined) {
var c = [];
for (var i = 0, len = el.length; i < len; ++i) {
c[c.length] = Y.Dom.get(el[i]);
}
return c;
}
return el;
},這段代碼寫得非常的精妙。坦白的說,上述代碼中的循環(huán)體,如果不加思索的話,恐怕就會寫成
for (var i = 0, len = el.length; i < len; ++i) {
c[c.length] = document.getElementById(el[i]);
}雖然也能正常工作,但是前面的判斷就失去了意義。
繼續(xù)走馬觀花,現(xiàn)在看看 getElementsByClassName 的內部機制。有關 getElementsByClassName 的詳細調用,可以參看 YUI 文檔。
getElementsByClassName: function(className, tag, root, apply) {
// 獲取 tag 標簽,默認為所有(“*”)
tag = tag || '*';
// 指定跟節(jié)點名
root = (root) ? Y.Dom.get(root) : null || document;
if (!root) {
return [];
}
// 初始化節(jié)點信息
var nodes = [],
elements = root.getElementsByTagName(tag),
re = getClassRegEx(className);
// 濾掉不符合規(guī)則的節(jié)點
for (var i = 0, len = elements.length; i < len; ++i) {
if ( re.test(elements[i].className) ) {
// 你一定很奇怪為什么用 nodes.length 而不是用 i
// 仔細考慮下 :^)
nodes[nodes.length] = elements[i];
// 執(zhí)行回調函數(shù)
if (apply) {
apply.call(elements[i], elements[i]);
}
}
}
return nodes;
},教科書式的 DOM 節(jié)點獲取和過濾,初始化數(shù)據(jù)以及操作數(shù)據(jù)都顯得非常的嚴謹而且正規(guī),YUI 的代碼讓我有幾分的“安全感”。類似的,再來一個 getElementsBy 函數(shù),相應代碼如下
getElementsBy: function(method, tag, root, apply) {
// 與上述函數(shù)相同,略
tag = tag || '*';
root = (root) ? Y.Dom.get(root) : null || document;
if (!root) {
return [];
}
var nodes = [],
elements = root.getElementsByTagName(tag);
for (var i = 0, len = elements.length; i < len; ++i) {
// 根據(jù)自定義函數(shù)返回值判斷節(jié)點的屬性
if ( method(elements[i]) ) {
nodes[nodes.length] = elements[i];
if (apply) {
apply(elements[i]);
}
}
}
return nodes;
},OK,今天就先到這里。
下面我們在 YAHOO.util.Dom 類中看看有哪些寶藏。目前思想已經(jīng)逐步的分裂,我看見個函數(shù)說個函數(shù)。
// 基本上可以認為是 document.getElementById 的翻版
get: function(el) {
// 如果已經(jīng)是 HTMLElement ,那么就直接返回
if (el && (el.nodeType || el.item)) {
return el;
}
// 如果是字符串,那么就返回有這個 ID 的 Element
if (YAHOO.lang.isString(el) || !el) {
return document.getElementById(el);
}
// 看起來是個數(shù)組,循環(huán)調用自身,獲取 Eelement
if (el.length !== undefined) {
var c = [];
for (var i = 0, len = el.length; i < len; ++i) {
c[c.length] = Y.Dom.get(el[i]);
}
return c;
}
return el;
},這段代碼寫得非常的精妙。坦白的說,上述代碼中的循環(huán)體,如果不加思索的話,恐怕就會寫成
for (var i = 0, len = el.length; i < len; ++i) {
c[c.length] = document.getElementById(el[i]);
}雖然也能正常工作,但是前面的判斷就失去了意義。
繼續(xù)走馬觀花,現(xiàn)在看看 getElementsByClassName 的內部機制。有關 getElementsByClassName 的詳細調用,可以參看 YUI 文檔。
getElementsByClassName: function(className, tag, root, apply) {
// 獲取 tag 標簽,默認為所有(“*”)
tag = tag || '*';
// 指定跟節(jié)點名
root = (root) ? Y.Dom.get(root) : null || document;
if (!root) {
return [];
}
// 初始化節(jié)點信息
var nodes = [],
elements = root.getElementsByTagName(tag),
re = getClassRegEx(className);
// 濾掉不符合規(guī)則的節(jié)點
for (var i = 0, len = elements.length; i < len; ++i) {
if ( re.test(elements[i].className) ) {
// 你一定很奇怪為什么用 nodes.length 而不是用 i
// 仔細考慮下 :^)
nodes[nodes.length] = elements[i];
// 執(zhí)行回調函數(shù)
if (apply) {
apply.call(elements[i], elements[i]);
}
}
}
return nodes;
},教科書式的 DOM 節(jié)點獲取和過濾,初始化數(shù)據(jù)以及操作數(shù)據(jù)都顯得非常的嚴謹而且正規(guī),YUI 的代碼讓我有幾分的“安全感”。類似的,再來一個 getElementsBy 函數(shù),相應代碼如下
getElementsBy: function(method, tag, root, apply) {
// 與上述函數(shù)相同,略
tag = tag || '*';
root = (root) ? Y.Dom.get(root) : null || document;
if (!root) {
return [];
}
var nodes = [],
elements = root.getElementsByTagName(tag);
for (var i = 0, len = elements.length; i < len; ++i) {
// 根據(jù)自定義函數(shù)返回值判斷節(jié)點的屬性
if ( method(elements[i]) ) {
nodes[nodes.length] = elements[i];
if (apply) {
apply(elements[i]);
}
}
}
return nodes;
},OK,今天就先到這里。
相關文章
學習YUI.Ext 第六天--關于樹TreePanel(Part 2異步獲取節(jié)點)
學習YUI.Ext 第六天--關于樹TreePanel(Part 2異步獲取節(jié)點)...2007-03-03學習YUI.Ext第七日-View&JSONView Part Two-一個畫室網(wǎng)站的案例
這篇文章主要介紹了學習YUI.Ext第七日-View&JSONView Part Two-一個畫室網(wǎng)站的案例2007-03-03Ext javascript建立超鏈接,進行事件處理的實現(xiàn)方法
如何在javasript建立超鏈接 應用到Ext中的樹控件事件處理2009-03-03