码迷,mamicode.com
首页 > 其他好文 > 详细

DOM的选择器

时间:2019-08-26 15:15:52      阅读:103      评论:0      收藏:0      [点我收藏+]

标签:first   html   code   sbo   asp   select   ons   nts   解析   

这几天学习了DOM的选择器,现在来进行一下总结分类。

1.DOM里的元素节点选择器

元素节点选择器包括id,class,name,tagname,高级,关系。

1.1 id选择器

   id:返回的是单个对象

   相关标签代码

<body>
    <div id="box">1</div>
    <div id="box">2</div>
    <div id="box">3</div>
    <div class="msg">
        <div class="sbox">
            <h2>二级标题</h2>
            <h2>二级标题</h2>
        </div>
        <h2>二级标题</h2>
        <h2>第二个二级标题</h2>
    </div>
    <div class="cont">4</div>
    <div class="cont">5</div>
    <div class="cont">6</div>
    <span>7</span>
    <span><em>hello</em></span>
    <span>9</span>
    <input type="text" name="user">
    <input type="text" name="user">
    <input type="text" name="pass">
</body>

 

   id选择器代码

  var box = document.getElementById("box");
    console.log(box)

控制台显示效果

技术图片

 

 

   

1.2 class选择器

 class:返回的是数组对象,如果要使用其中的元素,通过索引解析

 class选择器代码

var acont = document.getElementsByClassName("cont")
    console.log(acont)
    console.log(acont[0])
    console.log(acont[0].innerHTML)
    console.log(acont.innerHTML)

 控制台显示效果

技术图片

 

 

 

 

 

1.3 tagname选择器

 tagname:返回的是数组对象,如果要使用其中的元素,通过索引解析

 tagname选择器代码

var aspan = document.getElementsByTagName("span")
    console.log(aspan)
    console.log(aspan[1])
    console.log(aspan[1].innerHTML)
    console.log(aspan.innerHTML)

控制台显示效果

技术图片

 

 

 

 

1.4 name选择器

name:返回的是数组对象,如果要使用其中的元素,通过索引解析

 name选择器代码

var auser = document.getElementsByName("user")
    console.log(auser)

 控制台效果

技术图片

 

 

1.5高级选择器:ES5新增的

1.5.1.querySelector:返回的是单个对象

querySelector选择器代码

var ele = document.querySelector("#box")
console.log( ele)
var ele = document.querySelector(".cont")
console.log( ele)
var ele = document.querySelector("span")
console.log( ele)
var ele = document.querySelector(".msg h2")
console.log( ele)
var ele = document.querySelector(".msg>h2")
console.log( ele)

控制台显示效果

技术图片

 

1.5.2.querySelectorAll:返回的是数组对象,如果要使用其中的元素,通过索引解析

querySelectorAll选择器代码

var ele = document.querySelectorAll("#box")
console.log(ele[1])
var ele = document.querySelectorAll(".cont")
console.log(ele[1])
var ele = document.querySelectorAll("span")
console.log(ele[1])
var ele = document.querySelectorAll(".msg h2")
console.log(ele[1])
var ele = document.querySelectorAll(".msg>h2")
console.log(ele[1])

控制台效果

技术图片

1.6关系选择器

 1.6.1 父选子

var omsg = document.querySelector(".msg");
        console.log(omsg.children);
        console.log(omsg.children[0].innerHTML)

控制台效果

技术图片

1.6.2子选父

var osbox = document.querySelector(".sbox");
        console.log(osbox.parentNode);

技术图片

1.6.3选第一个子

 var omsg = document.querySelector(".msg");
        console.log(omsg.firstChild)

技术图片

1.6.4选最后一个子

var omsg = document.querySelector(".msg");
        console.log(omsg.lastElementChild)

技术图片

1.6.5 上一个兄弟

    var omsg = document.querySelector(".msg");
        console.log(omsg.previousElementSibling)

技术图片

1.6.6 下一个兄弟

    var omsg = document.querySelector(".msg");
        console.log(omsg.nextElementSibling)

技术图片

 

2其他节点选择器

<body>
    <span>qwe</span>
    <div class="box">
        <span>1</span>
        <p>2</p>
        hello
        <!-- 这是注释 -->
        <em>3</em>
    </div>
    <span>zxc</span>
</body>

2.1 父选子

 var obox = document.querySelector(".box")
            console.log(obox.childNodes)

技术图片

2.2 选上一个兄弟

 var obox = document.querySelector(".box")
            console.log(obox.previousSibling)
            console.log(obox.previousSibling.nodeName)

技术图片

2.3 选下一个兄弟

 var obox = document.querySelector(".box")
            console.log(obox.nextSibling)

技术图片

2.4 选第一个子和最后一个子

 var obox = document.querySelector(".box")
            console.log(obox.firstChild)
var obox = document.querySelector(".box")
            console.log(obox.lastChild)

技术图片

 

DOM的选择器

标签:first   html   code   sbo   asp   select   ons   nts   解析   

原文地址:https://www.cnblogs.com/mhcll/p/11412217.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!