原生JavaScript提供了一些选择器,用于选择和操作HTML元素,下面展示下常见选择器方法和之间的区别
1) getElementById方法通过元素的唯一标识符ID来选择元素。它返回指定ID的元素。
window.onload = function(){
let oDiv = document.getElementById('box')
console.log(oDiv)//
}
兼容性:getElementById方法支持所有常见浏览器版本
2) getElementsByName, 通过name属性获取元素
window.onload = function(){
let aNames=document.getElementsByName('box')
console.log(aNames)// NodeList(4) [div, span, div, input]
}
我是box2
我是pox4
getElementsByName方法返回的是一个NodeList集合,兼容性:IE10以下只能获取表单中带name的属性,IE10以上和chrome和FF高版本都可以兼容。(注:IE已废除不更新,所以不考虑IE下可以使用)
3) getElementsByClassName,通过元素的类名来选择元素。
window.onload = function(){
let aclass=document.getElementsByClassName('box')
console.log(aclass)//HTMLCollection(3) [input.box, div.box, div.box]
}
我是pox4
getElementsByClassName方法返回一个HTMLCollection集合。兼容性: IE9以下版本不兼容此方法,其他chrome,FF高版本兼容。(注:IE已废除不更新,所以不考虑IE下可以使用)
4)getElementsByTagName,通过元素的标签名称来选择元素。
window.onload = function(){
let aTags=document.getElementsByTagName('div')
console.log(aTags)
// HTMLCollection(4) [div#box, div, div.box, div.box, box: div#box]
}
我是box2
getElementsByTagName方法返回一个指定标签名的所有元素的HTMLCollection集合。兼容:兼容所有IE版本和chrome\FF常见浏览器版本。
5)querySelector, 通过CSS选择器来选择元素
window.onload = function(){
// 获取类名为myClass的元素(只匹配第一个)
let oClass = document.querySelector('.myClass');
console.log(oClass) //
// 获取ID为myId的元素
let oId = document.querySelector('#myId');
console.log(oId) //
// 获取多条件组合的元素,选取name为'big'且class为'bigName'的a标签(只匹配第一个)
let oA = document.querySelector("a[name='big'][class='bigName']");
console.log(oA) // 我是a1
// 选取class为‘classBox’的下的span标签(只匹配第一个)
let oSpan = document.querySelector(".classBox span");
console.log(oSpan) //我是span1
// 选取class为‘classBox’的下的i标签(只匹配第一个)
let oi = document.querySelector(".classBox > i");
console.log(oi) //我是i标签1
}
我是i标签1
我是i标签2
我是span1
我是span2
我是span
querySelector它返回第一个匹配选择器的元素。几乎支持所有CSS选择器的方式。兼容性: IE10以下不支持,其他chrome、FF高版本支持。(注:IE已废除不更新,所以不考虑IE下可以使用)
6)querySelectorAll, 通过CSS选择器来选择元素, 返回所有匹配选择器的元素的集合。
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]
}
我是i标签1
我是i标签2
我是span1
我是span2
我是span
-
我strong
-
我strong
-
我是p1
我是p2
我是p3
-
我是p4
我是p5
总之,常见的原生JS选择器一般由上面几种方式,在当前不考虑IE的情况下(IE已停更),所有选择器都可以使用。其中querySelectorAll和querySelector最为强大,几乎支持了所有css选择器的方式,使用起来更为方便