新增的querySelector、querySelectorAll测试

从IE9开始DOM开始支持支持CSS的选择器了,DOM提供了两个接口querySelector得到一个DOMquerySelectorAll得到一组DOM一个个的解释这些选择器也没有必要,我

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

从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>  
<a href="http://hovertree.com/">何问起</a>
</body>  

添加一个简单的样式

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

加一个jQuery的脚本

<script src=“http://down.hovertree.com/jquery/jquery-1.12.3.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 = "";  
                }  
                );  
                //本次匹配的元素加入样式   hovertree.com
                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来辅助就可以了。

更多特效:http://www.cnblogs.com/roucheng/p/texiao.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/120608.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 计算机最炫民族风教案,辽师大版信息技术四下第一单元第6课《最炫民族风》教案1.doc…[通俗易懂]

    计算机最炫民族风教案,辽师大版信息技术四下第一单元第6课《最炫民族风》教案1.doc…[通俗易懂]辽师大版信息技术四下第一单元第6课《最炫民族风》教案1.doc文档编号:536835文档页数:2上传时间:2019-01-13文档级别:文档类型:doc文档大小:35.00KB第第6课课最炫民族风最炫民族风教学目标设计知识与技能目标通过学习使学生掌握word里“页面设置”里“页边距”和“纸张”的使用和操作方法。在掌握以前学习有关知识的基础上,能够较灵活的应用该设置对页面进行调…

    2022年9月22日
    6
  • 关于中秋节的古诗_fontstrikethru

    关于中秋节的古诗_fontstrikethru现在网上的博客好多都是复制粘贴的,哎,能把问题讲清楚的不多。这里讲一下KFold.split话不多说,用例子说话:fromsklearn.model_selectionimportKFoldkf=KFold(n_splits=5,random_state=43,shuffle=True)a=[[1,2],[3,4],[5,6],[7,8],[9,10]]b=[1…

    2026年1月29日
    6
  • HTML实用的网页代码大全[通俗易懂]

    HTML实用的网页代码大全[通俗易懂]【一】:符号&lt;p&gt;段落&lt;/p&gt; &lt;h&gt;标题&lt;/h&gt;(h1—h6) &lt;br&gt;:换行 &lt;hr&gt;:分割线 左右尖括号:&amp;lt;&amp;gt; &amp;表示为:&amp;amp "表示为:&amp;quot; 表格形式&lt;table&gt;

    2022年6月3日
    65
  • linux设置网络适配器

    linux设置网络适配器1 安装完虚拟机后 我们的电脑的适配器会多出两个 VMnet1 和 VMnet82 打开虚拟机设置的网络适配器 可以看到网络连接方式有 桥接 NAT 仅主机 3 其中桥接使用主机的适配器 NAT 使用 VMnet8 仅主机模式使用 VMnet14 一般我们使用桥接即可 但是主机不止有一块网络适配器 一般无线和有线网卡各一个 我们需要选择主机能用的适配器 设置方式如下

    2026年2月6日
    0
  • pycharm django环境搭建_django创建项目和应用的命令

    pycharm django环境搭建_django创建项目和应用的命令一、配置并准备你的环境1、首先,在设置里面选择好环境,这里我们使用python3.7(Ps:打开pycharm后—>File—>settings—>键入ProjectInterpreter),点击如下图所示的齿轮后出现Add。2、添加设置你自己安装的python后点击OK3、我们会看到现在都有什么东西,然后点击加号,下载django包。…

    2025年7月5日
    3
  • linux抓包命令详解_linux抓包命令指定ip和端口

    linux抓包命令详解_linux抓包命令指定ip和端口linux抓包命令tcpflow-cieth0dstport6060tcpdump-ieth0dstport6060案例:参考文档:https://blog.csdn.net/weixin_34124651/article/details/88267519

    2022年10月10日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号