下面我們在 YAHOO.util.Dom 類中看看有哪些寶藏。目前思想已經逐步 " /> 国产成人在线视频网站,91桃色在线看片,美女视频永久黄网站免费观看韩国

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

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

先繞開頭部很多的 if...else (其實就是定義 toCamel 與 getStyle 兩個函數) - 由于瀏覽器的實現不統一,才造成如此麻煩的情況,回頭可以聊聊這些代碼。

下面我們在 YAHOO.util.Dom 類中看看有哪些寶藏。目前思想已經逐步的分裂,我看見個函數說個函數。

// 基本上可以認為是 document.getElementById 的翻版
get: function(el) {
    // 如果已經是 HTMLElement ,那么就直接返回
    if (el && (el.nodeType || el.item)) {
        return el;
    }

    // 如果是字符串,那么就返回有這個 ID 的 Element
    if (YAHOO.lang.isString(el) || !el) {
        return document.getElementById(el);
    }

    // 看起來是個數組,循環調用自身,獲取 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;
},這段代碼寫得非常的精妙。坦白的說,上述代碼中的循環體,如果不加思索的話,恐怕就會寫成

for (var i = 0, len = el.length; i < len; ++i) {
    c[c.length] = document.getElementById(el[i]);
}雖然也能正常工作,但是前面的判斷就失去了意義。

繼續走馬觀花,現在看看 getElementsByClassName 的內部機制。有關 getElementsByClassName 的詳細調用,可以參看 YUI 文檔。

getElementsByClassName: function(className, tag, root, apply) {
    // 獲取 tag 標簽,默認為所有(“*”)
    tag = tag || '*';
    // 指定跟節點名
    root = (root) ? Y.Dom.get(root) : null || document; 
    if (!root) {
        return [];
    }

    // 初始化節點信息
    var nodes = [],
        elements = root.getElementsByTagName(tag),
        re = getClassRegEx(className);

    // 濾掉不符合規則的節點
    for (var i = 0, len = elements.length; i < len; ++i) {
        if ( re.test(elements[i].className) ) {
            // 你一定很奇怪為什么用 nodes.length 而不是用 i
            // 仔細考慮下 :^)
            nodes[nodes.length] = elements[i];
            // 執行回調函數
            if (apply) {
                apply.call(elements[i], elements[i]);
            }
        }
    }

    return nodes;
},教科書式的 DOM 節點獲取和過濾,初始化數據以及操作數據都顯得非常的嚴謹而且正規,YUI 的代碼讓我有幾分的“安全感”。類似的,再來一個 getElementsBy 函數,相應代碼如下

getElementsBy: function(method, tag, root, apply) {
    // 與上述函數相同,略
    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) {
        // 根據自定義函數返回值判斷節點的屬性
        if ( method(elements[i]) ) {
            nodes[nodes.length] = elements[i];
            if (apply) {
                apply(elements[i]);
            }
        }
    }

    return nodes;
},OK,今天就先到這里。

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

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

主站蜘蛛池模板: 久久久久国产一级毛片高清片 | 大jjjj免费看视频 | 小说区图片区综合久久88 | 色婷婷在线观看视频 | 欧美极品美軳人人体 | 亚洲成a人一区二区三区 | 中文字幕日产每天更新40 | 黄色网络在线观看 | 色婷婷婷婷 | 韩国美女一级片 | 久久香蕉综合色一综合色88 | 日韩中文字幕精品久久 | 亚洲精品日韩中文字幕久久久 | 亚洲妇人成熟性成熟美女 | 久久综合狠狠综合久久 | 中文字幕天天躁日日躁狠狠 | 日韩a级大片 | 亚洲一区二区免费在线观看 | 国产福利一区二区三区在线视频 | 色婷五月 | 欧美另类videosbestsex亚洲 | 欧美三级欧美成人高清www | 欧美视频a| 加勒比在线免费视频 | 中国一级特黄 | 日产精品一区二区免费 | 婷婷久久综合九色综合九七 | 爱婷婷网站在线观看 | 97久久精品国产精品青草 | 最新日本免费一区二区三区中文 | 亚洲成人综合网站 | 麻豆视频91| 国内精品视频九九九九 | 精品久久久久久久免费加勒比 | 国产综合在线观看视频 | 在线欧美视频 | 免费的成人a视频在线观看 免费的黄色片视频 | 成人中文字幕一区二区三区 | 亚洲精品高清国产一久久 | 图片区小说区区国产明星 | 本道久久综合88全国最大色 |