下面我們在 YAHOO.util.Dom 類中看看有哪些寶藏。目前思想已經(jīng)逐步 " /> 麻豆狠色伊人亚洲综合网站,欧美男女爱爱,亚洲无线码一区在线观看

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

YUI 讀碼日記之 YAHOO.util.Dom - Part.1

先繞開頭部很多的 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)調(diào)用自身,獲取 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 的內(nèi)部機制。有關 getElementsByClassName 的詳細調(diào)用,可以參看 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í)行回調(diào)函數(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,今天就先到這里。

JavaScript技術YUI 讀碼日記之 YAHOO.util.Dom - Part.1,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 中国特级黄色大片 | 国产又黄又粗又爽又色的视频软件 | 国产骚妇BB网 | 成人在线视频免费看 | 亚洲人成伊人成综合网久久久 | 久久sese| 思思99精品国产自在现线 | 亚洲成人一区 | 国模孕妇模特季玥之粉红 | yellow在线观看免费高清的日本 | 国产精品99久久久久久AV下载 | 理论片午午伦夜理片影院 | 在线va无卡无码高清 | 国产精品点击进入在线影院高清 | 动漫美女的阴 | 全免费午夜一级毛片 | 伊人在线视频 | 国产精品免费视频能看 | 6 10young俄罗斯 | 国产免费变态视频网址网站 | 日本久久久WWW成人免费毛片丨 | 成人在线免费视频播放 | 色戒2小时38分在线观看 | 在线播放真实国产乱子伦 | 美女用手扒开粉嫩的屁股 | 久久操热在线视频精品 | 欧美多毛的大隂道 | 插骚妇好爽好骚 | 熟女人妻AV五十路六十路 | 中文字幕无码亚洲视频 | 亚洲 日本 欧美 中文字幕 | 欧美国产在线一区 | 好男人免费观看在线高清WWW | 天天爽夜夜爽夜夜爽 | 狼人大香伊蕉国产WWW亚洲 | 9久久免费国产精品特黄 | 亚洲成熟人网站 | 特大黑人娇小亚洲女mp4 | 午夜男女爽爽羞羞影院在线观看 | 青青久在线视频免费观看 | 亚洲一区在线播放 |