Bootstrap

原生JS-常用选择器详解

原生JavaScript提供了一些选择器,用于选择和操作HTML元素,下面展示下常见选择器方法和之间的区别

1) getElementById方法通过元素的唯一标识符ID来选择元素。它返回指定ID的元素。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        window.onload = function(){
            let oDiv = document.getElementById('box')
            console.log(oDiv)//<div id="box">我是ID</div>
        }
    </script>
</head>
<body>
    <div id="id">我是ID</div>
</body>
</html>

兼容性:getElementById方法支持所有常见浏览器版本

2) getElementsByName, 通过name属性获取元素

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        window.onload = function(){
            let aNames=document.getElementsByName('box')
            console.log(aNames)// NodeList(4) [div, span, div, input]
        }
    </script>
</head>
<body>
    <div id="box">我是ID</div>
    <div  name="box">我是box1</div>
    <span name="box">我是box2</span>
    <div  name="box">我是box3</div>
    <br />
    我是pox4<input name="box" type="text" />
</body>
</html>

 getElementsByName方法返回的是一个NodeList集合,兼容性:IE10以下只能获取表单中带name的属性,IE10以上和chrome和FF高版本都可以兼容。(注:IE已废除不更新,所以不考虑IE下可以使用)

3) getElementsByClassName,通过元素的类名来选择元素。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        window.onload = function(){
           
            let aclass=document.getElementsByClassName('box')
            console.log(aclass)//HTMLCollection(3) [input.box, div.box, div.box]
        }
    </script>
</head>
<body>
    <div  class="box2">我是box3</div>
    <br />
    我是pox4<input class="box" type="text" />
    <div  class="box">我是box1</div>
    <div  class="box">我是box1</div>
</body>
</html>

getElementsByClassName方法返回一个HTMLCollection集合。兼容性: IE9以下版本不兼容此方法,其他chrome,FF高版本兼容。(注:IE已废除不更新,所以不考虑IE下可以使用)

4)getElementsByTagName,通过元素的标签名称来选择元素。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        window.onload = function(){
            let aTags=document.getElementsByTagName('div')
            console.log(aTags)
            // HTMLCollection(4) [div#box, div, div.box, div.box, box: div#box]
        }
    </script>
</head>
<body>
    <div id="box">我是ID</div>
    <div  name="box">我是box1</div>
    <span name="box">我是box2</span>
    <div  class="box">我是box3</div>
    <div  class="box">我是box4</div>
</body>
</html>

getElementsByTagName方法返回一个指定标签名的所有元素的HTMLCollection集合。兼容:兼容所有IE版本和chrome\FF常见浏览器版本。

5)querySelector, 通过CSS选择器来选择元素

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        window.onload = function(){
            // 获取类名为myClass的元素(只匹配第一个)
            let oClass = document.querySelector('.myClass');
            console.log(oClass) // <div  class="myClass">我是myClass1</div>
            
            // 获取ID为myId的元素
            let oId = document.querySelector('#myId');
            console.log(oId) //  <div  id="myId">我是myClass2</div>

            // 获取多条件组合的元素,选取name为'big'且class为'bigName'的a标签(只匹配第一个)
            let oA = document.querySelector("a[name='big'][class='bigName']");
            console.log(oA) // <a href="#" name="big" class="bigName">我是a1</a>

            // 选取class为‘classBox’的下的span标签(只匹配第一个)
            let oSpan = document.querySelector(".classBox span");
            console.log(oSpan) //<span>我是span1</span>

            // 选取class为‘classBox’的下的i标签(只匹配第一个)
            let oi = document.querySelector(".classBox > i");
            console.log(oi) //<i>我是i标签1</i>
        }

    </script>
</head>
<body>
    <div  class="myClass">我是myClass1</div>
    <div  class="myClass">我是myClass2</div>
    <div  id="myId">我是myClass2</div>
    <a href="#" name="big" class="bigName">我是a1</a>
    <a href="#" name="big" class="bigName">我是a2</a>
    <div class="classBox">
        <i>我是i标签1</i>
        <i>我是i标签2</i>
        <span>我是span1</span>
        <span>我是span2</span>
    </div>
    <div class="classBox">
        <span>我是span</span>
    </div>
</body>
</html>

querySelector它返回第一个匹配选择器的元素。几乎支持所有CSS选择器的方式。兼容性: IE10以下不支持,其他chrome、FF高版本支持。(注:IE已废除不更新,所以不考虑IE下可以使用)

6)querySelectorAll, 通过CSS选择器来选择元素, 返回所有匹配选择器的元素的集合。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <script>
        window.onload = function(){
            // 获取所有类名为myClass的元素
            let aClass = document.querySelectorAll('.myClass');
            console.log(aClass) // NodeList(2) [div.myClass, div.myClass]

            // 获取所有div标签元素
            let aDiv = document.querySelectorAll('div');
            console.log(aDiv) 
            // NodeList(5) [div.myClass, div.myClass, div#myId, div.classBox, div.classBox]

            // 获取多个条件组合下的元素,选取name为'big'的,并且class为'bigName'的a标签
            let aA = document.querySelectorAll("a[name='big'][class='bigName']");
            console.log(aA) // NodeList(2) [a.bigName, a.bigName]

            // 选取class为‘classBox’的下的span标签
            let aSpan = document.querySelectorAll(".classBox span");
            console.log(aSpan) //NodeList(3) [span, span, span]

            // 选取class为‘classBox’的下的i标签(只匹配第一个)
            let ai = document.querySelectorAll(".classBox > i");
            console.log(ai) // NodeList(2) [i, i]

            // "多个" 选取条件, 用逗号隔开 (相当于 X 或 Y)
            let aX = document.querySelectorAll(".classX, #idY");
            console.log(aX) // NodeList(2) [div#idY, div.classX]

            // 选取类名为list下,类名为listLi的Li标签,下面的全部兄弟节点们         
            let aBrothers = document.querySelectorAll(".list li.listLi1 ~ li ");
            console.log(aBrothers)// NodeList(3) [li.listLi, li.listLi3, li.listLi2]

            // 选取类名为list下,类名为listLi的Li标签,紧挨着的下一个兄弟节点    
            let prview = document.querySelectorAll(".list li.listLi1 + li ");
            console.log(prview)// NodeList [li.listLi]
        }

    </script>
</head>
<body>
    <div  class="myClass">我是myClass1</div>
    <div  class="myClass">我是myClass2</div>
    <div  id="myId">我是myClass2</div>
    <a href="#" name="big" class="bigName">我是a1</a>
    <a href="#" name="big" class="bigName">我是a2</a>
    <div class="classBox">
        <i>我是i标签1</i>
        <i>我是i标签2</i>
        <span>我是span1</span>
        <span>我是span2</span>
    </div>
    <div class="classBox">
        <span>我是span</span>
    </div>
    <div id="idY">我是idY</div>
    <div class="classX">我是classX</div>
    <ul class="list">
        <li class="listLi4">
            <strong>我strong</strong>
         </li>
         <li class="listLi1">
            <strong>我strong</strong>
         </li>
         <li class="listLi">
            <p>我是p1</p>
            <p>我是p2</p>
            <p>我是p3</p>
         </li>
         <li class="listLi3">
            <p>我是p4</p>
            <p>我是p5</p>
         </li>
         <li class="listLi2"></li>
    </ul>
</body>
</html>

总之,常见的原生JS选择器一般由上面几种方式,在当前不考虑IE的情况下(IE已停更),所有选择器都可以使用。其中querySelectorAll和querySelector最为强大,几乎支持了所有css选择器的方式,使用起来更为方便

;