《JavaScript高级程序设计 (第3版)》学习笔记40:chapter_11-1 选择符API

这是第40篇笔记!
让学习“上瘾”,成为更好的自己!!!

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>选择符API</title>
    <style>
    .important {
        color: red;
    }
    
    </style>
</head>

<body>

    <div id="myDiv">
        <h3>来自炎黄子孙的心声1</h3>
        我爱我的 <em>国家</em>,就像爱我的<em>母亲</em>一样!一刻都不会变!
        <h3>来自炎黄子孙的心声2</h3>
    </div>


    <p>我们是<strong>中国人</strong>,我们来自<strong>中国</strong></p>


    <script>
        /*
            对DOM的2个主要的扩展是选择符API和HTML5
            
            选择符API --> 众多JavaScript库中最常用的一项功能,根据CSS选择符选择与某个模式匹配的DOM元素
            
            选择符API Level1的核心是两个方法:querySelector() and querySelectorAll()
            在兼容浏览器中,可以通过“Document” and “Element”类型的实例调用他们


            */
        
        // 1, querySelector() --> 接收一个CSS选择符,返回与该模式匹配的“第一个”元素
        //                        如果没有找到匹配的元素,返回null

        // 取得body元素
        var body = document.querySelector('body');

        // 取得ID为‘myDiv’的第一个元素
        var selected = document.querySelector('#myDiv');
        // console.log(selected);
        // ---> 通过Document类型调用querySelector()方法时,会在文档元素(html)的范围内查找匹配的元素 

        // 取得类为“button”的第一个图像元素
        var img = document.body.querySelector('img.button');

        var div1 = document.getElementById('myDiv');
        console.log(div1);
        var h3 = div1.querySelector('h3');
        console.log(h3);
        // ---> 通过Element类型调用querySelector()方法时,只会在该元素后代元素的范围内查找匹配的元素
        
        // 【注意】 如果传入了不被支持的选择符,querySelector()会报错



        // 2, querySelectorAll() --> 接收一个CSS选择符,返回与该模式匹配的“所有”元素,一个NodeList的实例
        // 【注意】  1,其返回的值实际上是带有所有属性和方法的NodeList,而其底层实现类似于一组元素的“快照”,而非不断对文档进行搜索的动态查询
        //          2,只要传给querySelectorAll()的方法的CSS选择符有效,该方法都会返回一个NodeList对象,不管是否匹配到元素

        // 取得某<div>中的所有<em>元素(类似于getElementByTagName('em'))
        // var ems = document.getElementById('myDiv').querySelectorAll('em');
        
        // 取得类为“selected”的所有元素
        var selecteds = document.querySelectorAll('.selected');


        var i, len, strong;
        var strongs = document.querySelectorAll('p strong');
        console.log(strongs);
        for(i = 0, len = strongs.length; i < len; i ++){
            strong = strongs[i];
            strong.className = 'important';

        }


        // 3, matchesSelector() --> 接收一个CSS选择符,如果调用元素与该选择符匹配,返回true;否则,返回false
        // 选择符API Level 2为Element类型新增的这个方法

        // if(document.body.matchesSelector('body.page1')){
        //     // true
        // }

        // 在取得某个元素引用的情况下,使用这个方法能够方便地检测他是否被querySelector() or querySelectorAll()方法返回


        // 该方法未得到足够的支持,使用时最好编写一个“包装函数”
        function matchesSelector(element, selector){
            if(element.matchesSelector){
                return element.matchesSelector(selector);
            } else if(element.msMatchesSelector){
                return element.msMatchesSelector(selector);
            } else if (element.mozMatchesSelector){
                return element.mozMatchesSelector(selector);
            } else if (element.webkitMatchesSelector){
                return element.webkitMatchesSelector(selector);
            }else {
                throw new error('Not supported!');
            }
        }




    </script>


</body>

</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值