下面我們?cè)?YAHOO.util.Dom 類(lèi)中看看有哪些寶藏。目前思想已經(jīng)逐步 " /> 久久天天,九九精品热,国产一区二区精品久久

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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

先繞開(kāi)頭部很多的 if...else (其實(shí)就是定義 toCamel 與 getStyle 兩個(gè)函數(shù)) - 由于瀏覽器的實(shí)現(xiàn)不統(tǒng)一,才造成如此麻煩的情況,回頭可以聊聊這些代碼。

下面我們?cè)?nbsp;YAHOO.util.Dom 類(lèi)中看看有哪些寶藏。目前思想已經(jīng)逐步的分裂,我看見(jiàn)個(gè)函數(shù)說(shuō)個(gè)函數(shù)。

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

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

    // 看起來(lái)是個(gè)數(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;
},這段代碼寫(xiě)得非常的精妙。坦白的說(shuō),上述代碼中的循環(huán)體,如果不加思索的話,恐怕就會(huì)寫(xiě)成

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

繼續(xù)走馬觀花,現(xiàn)在看看 getElementsByClassName 的內(nèi)部機(jī)制。有關(guān) getElementsByClassName 的詳細(xì)調(diào)用,可以參看 YUI 文檔。

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

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

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

    return nodes;
},教科書(shū)式的 DOM 節(jié)點(diǎn)獲取和過(guò)濾,初始化數(shù)據(jù)以及操作數(shù)據(jù)都顯得非常的嚴(yán)謹(jǐn)而且正規(guī),YUI 的代碼讓我有幾分的“安全感”。類(lèi)似的,再來(lái)一個(gè) getElementsBy 函數(shù),相應(yīng)代碼如下

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é)點(diǎn)的屬性
        if ( method(elements[i]) ) {
            nodes[nodes.length] = elements[i];
            if (apply) {
                apply(elements[i]);
            }
        }
    }

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

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

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

主站蜘蛛池模板: 所求皆所愿| 电影名《瞎子传奇》| 藏文作文| ktv视频| 人设oc素材| ,xx| 延边卫视节目表| 历代高僧大德开悟诗100首| dj视频mv| 面部八大皱纹图| 美国派7| 欲情电影在线看| 爱情天梯| 妈妈写给叛逆儿子的信看哭孩子| 女王耳光| 王艺潼| 黄雀电视剧高清完整版| 从此以后歌词| 林蛟| 人民日报评墨茶| 女人 电影| 美女操帅哥| 饶俊| 美娜个人资料简介| hugh grant| 夫妻之间的理性| 樱井步| 违规吃喝研讨发言材料| 王盼盼| 无内裤秘书| 六年级上册英语书电子版翻译| 最美情侣高清免费观看视频大全| 肖颖| 朱莉与朱莉娅| 十里承欢电影版免费播放| po参加的综艺节目| 王牌替身免费观看全集| 水牛城66| 秀人网周妍希| 小数加减法100道题| 电影在线观看网址|