javascript技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > JavaScript > javascript技巧 > js中document.querySelector()方法

js中的document.querySelector()方法举例详解

作者:linlinlove2

这篇文章主要给大家介绍了关于js中document.querySelector()方法的相关资料,document.querySelector是JavaScript中的一个内置方法,用于通过CSS选择器选择文档中的第一个匹配元素,需要的朋友可以参考下

1、常用的三种获取元素的js方式

1 document.getElementById("");
2 document.getElementsByClassName();
3 document.getElementsByTagName();

var doc=document;
var box=doc.getElementById("box");
var li=box.getElementsByTagName("li");
var surfaces=box.getElementsByClassName("surfaces");

querySelector()可以直接加点击事件,而querySelectorAll()不能直接加点击事件

2、querySelector()

var node = document.querySelector(“#lover”); 
// 获取文档中的第一个id=lover的元素
var node = document.querySelector(“.lover”); 
// 获取文档中的第一个class=“lover"的元素
var node = document.querySelector(“p.lover”); 
// 获取class=“lover” 的第一个p元素
var node = document.querySelector(“a[target]”);
// 获取第一个带target属性的a元素
var element = document.querySelector(‘.foo,.bar');
//返回带有foo或者bar样式类的首个元素
document.querySelector(“body”).style=”"; 
// 移除style属性
document.querySelector(“h2,h3”).style.backgroundColor = “blue”;
//为文档的第一个h2元素添加背景颜色,但是,如果文档中

位于元素之前,元素将会被设置指定的背景颜色,总结,多元素选择时,哪个先匹配就是谁咯,只有一个被选中。
querySelector() 方法仅仅返回匹配指定选择器的第一个元素。

3、querySelectorAll

elementList = document.querySelectorAll(selectors);

elementList 是一个静态的 NodeList 类型的对象。

selectors 是一个由逗号连接的包含一个或多个 CSS 选择器的字符串。

查找文档中共包含 “target” 属性的 标签,并为其设置边框:

var x = document.querySelectorAll("a[target]");
var i;
for (i = 0; i < x.length; i++) {
x[i].style.border = "10px solid red";
}

-------------------------------------------
let t0 = window.performance.now();
let li = document.querySelectorAll('li');
console.log("li 的数量", li.length);
for (let i = 0; i < li.length; i++) {
    li[i].textContent = i;
}
let t1 = window.performance.now();
console.log("耗时" + (t1 - t0) + "毫秒");

当页面中出现多个相同class标签(或者多个相同标签(比如多个div))时,如果你需要返回所有的元素,请使用 querySelectorAll() 方法替代。

该方法返回所有满足条件的元素,结果是个nodeList集合。查找规则与前面所述一样。 ---->querySelectorAll 得到一个伪数组 DOM。

ParentNode.querySelectorAll()的结果是NodeList数组,但是又不是一般的js数组(Array),所以也不能直接调用Array的方法

<div id="box">

<ul>
<li data-href='http://www.qq.com'>tagname 111</li>
<li class="surfaces">这是clase? 222</li>
<li class="surfaces">这是class333</li>
<li class="surfaces" data-href='http://www.baidu.com'>这是class444</li>
</ul>

</div>
<br>

document.getElementById("box").addEventListener("click", function(){
var attr=document.querySelectorAll('[data-href]');
console.log(attr);
},!1);
<input type="checkbox" name="gender" value="male" checked>
<input type="checkbox" name="gender" value="female">

<div lang="en"><q>This English quote has a <q>nested</q> quote inside.</q></div>
<div lang="fr"><q>This French quote has a <q>nested</q> quote inside.</q></div>
<div lang="de"><q>This German quote has a <q>nested</q> quote inside.</q></div>

<input type="text" placeholder="我是占位符">
<input type="text" placeholder="我是占位符" value="我的 value 遮盖了占位符">

let target = document.querySelector('input[type="checkbox"]:checked');
console.log('使用 querySelector 查找 ', target)

let fr = document.querySelector('div:lang(fr)');
console.log('使用 querySelector 查找 ', fr);

let pl = document.querySelector('input:placeholder-shown');
console.log('使用 querySelector 查找 ', pl);

document.querySelector.bind和document.querySelectorAll.bind

<div id="box">
<ul>
<li >tagname 111</li>
<li class="surfaces">这是clase 222</li>
<li class="surfaces">这是class333</li>
<li class="surfaces">这是class444</li>
</ul>
</div>

--------------------------------------------------------------------------

var query_id=query('#box'); //dom id 
var query_class=query('.surfaces'); // dom class 
var query_tagname=query('li') //dom 标签

console.log('query'+query_id.innerHTML); //

console.log('query'+query_class.innerHTML); 第一个222

console.log('query'+query_tagname.innerHTML); 第一个222

--------------------------------------------------------------------------

1 var query = document.querySelector.bind(document); //单个的
var query_id=query('#box'); //dom id
var query_class=query('.surfaces'); // dom class
var query_tagname=query('li') //dom 标签
query_id.addEventListener('click',function(){
console.log('click_query_id'+this.innerHTML);   //click surfaces 2222
});

query_class.addEventListener('click',function(){
var e=e||window.event;
console.log('click_query_class'+this.innerHTML); //click surfaces 2222
e.stopPropagation();
});

query_tagname.addEventListener('click', function(e){
var e=e||window.event;
console.log('click_query_tagname' + this.innerHTML); //click surfaces 2222
e.stopPropagation();
});

总结 

到此这篇关于js中document.querySelector()方法的文章就介绍到这了,更多相关js中document.querySelector()方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文