querySelector、querySelectorAll和CSS3 Selectors一起來

從IE9開始DOM開始支持支持CSS的選擇器了,DOM提供了兩個接口

querySelector 得到一個DOM

querySelectorAll 得到一組DOM

一個個的解釋這些選擇器也沒有必要,我們結合前面的數組知識,寫一段代碼來說明。頁面上有一組元素,然後會依據我們數組中的預訂選擇值選擇相應元素,並將背景變紅色,同時提示選擇器的含義。這樣的代碼便於運行理解和擴展。

html的結構部分

<body>
    <div>
        <input type="button" value="開始測試" />
        <span></span><span></span>
    </div>
    <ol>
        <li title="abc1">
            <h2 title="abc">
                Hello</h2>
        </li>
        <li title="abc2">
            <input type="checkbox" checked="checked" />
            <input type="checkbox" />
            <input type="checkbox" />
        </li>
        <li title="abc3"></li>
        <li title="abc4">
            <ul>
                <li title="41abc">
                    <input type="text" readonly="true" />
                    <input type="text" />
                </li>
                <li title="42abc">
                    <input type="button" value="disabled" disabled="disabled" />
                </li>
                <li title="43abc4"></li>
                <li title="44abc4">
                    <input type="radio" checked="checked" />
                    <input type="radio" />
                    <input type="radio" checked="checked" />
                </li>
            </ul>
        </li>
        <li title="abc5"></li>
        <li title="abc6"></li>
        <li title="abc7"></li>
        <li title="abc8"><a href="#">go</a></li>
        <li title="abc9"></li>
    </ol>
    <p>
        text</p>
</body>

添加一個簡單的樣式

<style>
    .box
    {
        background-color: Red;
    }
</style>

加一個jQuery的腳本

<script src="js/jquery-1.7.1.min.js" type="text/javascript"></script>

然後就是我們的測試代碼了

<script type="text/javascript">

    var tip = ["指定元素名稱", "屬性中包含", "屬性開始", "屬性結束", "屬性等於",
            "html部分", "元素內容爲空白", "錨",
            "子元素", "兄弟元素", "第一個", "最後一個元素", "第2個", "倒數第2個",
            "奇數", "偶數", "類型一致的奇數", "類型一致的偶數",
            "從第3個算起,   每隔2個(包含第2個)", "只有一個子元素",
            "可用狀態", "不可用狀態", "只讀", "非只讀", "選取狀", "非選取狀態", "一半狀態", "不包含"
            ];

    var selectors = ["ol",
                    "[title*=abc]", "[title^=abc]", "[title$=abc]", "[title=abc]",
                    ":root",
                    ":empty",
                    ":target",
                    "ol li",
                    "ol~p",
                    "ol li:first-child", "ol li:last-child", "ol li:nth-child(2)", "ol li:nth-last-child(2)",
                    "ol li:nth-child(odd)", "ol li:nth-child(even)", "ol li:nth-of-type(odd)", "ol li:nth-of-type(even)",
                    "li:nth-child(2n+3)",
                    "ol li:only-child",
                    ":enabled", ":disabled", ":read-only", ":read-write",
                    ":default", ":checked", ":indeterminate",
                    "ol li:not(:first-child)"
                    ];


    $(
    function() {
        $(":button").click(
        function() {
            selectors.forEach(
            function(item, index) {
                //把上次有box樣式的元素清空下
                Array.prototype.slice.call(document.querySelectorAll(".box")).forEach(
                function(e, i) {
                    e.className = "";
                }
                );
                //本次匹配的元素加入樣式
                Array.prototype.slice.call(document.querySelectorAll(item)).forEach(
                function(e, i) {
                    e.className = "box";
                }
                );
                $("span:eq(0)").html(item);
                $("span:eq(1)").html(tip[index]);
                alert("next");
            }
            );
        }
        );
    }
    );
</script>

我們準備了兩個數組,一個存放選擇器,一個存放選擇器的說明。對selectors數組多forEach便利,根據選擇器對元素進行添加樣式,以可以看到樣式結果。

需要說明下的是

document.querySelectorAll(".box")得到的不是數組,是nodelist,雖然可以類似數組的for,但真的不是數組,不能直接對其使用數組的方法forEach,如果我們需要轉換爲數組,我們可以用Array.prototype.slice.call來輔助就可以了。




發佈了199 篇原創文章 · 獲贊 8 · 訪問量 59萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章