js中的document.querySelector()方法舉例詳解
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()可以直接加點(diǎn)擊事件,而querySelectorAll()不能直接加點(diǎn)擊事件
2、querySelector()
var node = document.querySelector(“#lover”); // 獲取文檔中的第一個(gè)id=lover的元素 var node = document.querySelector(“.lover”); // 獲取文檔中的第一個(gè)class=“l(fā)over"的元素 var node = document.querySelector(“p.lover”); // 獲取class=“l(fā)over” 的第一個(gè)p元素 var node = document.querySelector(“a[target]”); // 獲取第一個(gè)帶target屬性的a元素 var element = document.querySelector(‘.foo,.bar'); //返回帶有foo或者bar樣式類的首個(gè)元素 document.querySelector(“body”).style=”"; // 移除style屬性 document.querySelector(“h2,h3”).style.backgroundColor = “blue”; //為文檔的第一個(gè)h2元素添加背景顏色,但是,如果文檔中
位于元素之前,元素將會被設(shè)置指定的背景顏色,總結(jié),多元素選擇時(shí),哪個(gè)先匹配就是誰咯,只有一個(gè)被選中。
querySelector() 方法僅僅返回匹配指定選擇器的第一個(gè)元素。
3、querySelectorAll
elementList = document.querySelectorAll(selectors);
elementList 是一個(gè)靜態(tài)的 NodeList 類型的對象。
selectors 是一個(gè)由逗號連接的包含一個(gè)或多個(gè) CSS 選擇器的字符串。
查找文檔中共包含 “target” 屬性的 標(biāo)簽,并為其設(shè)置邊框:
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 的數(shù)量", li.length); for (let i = 0; i < li.length; i++) { li[i].textContent = i; } let t1 = window.performance.now(); console.log("耗時(shí)" + (t1 - t0) + "毫秒");
當(dāng)頁面中出現(xiàn)多個(gè)相同class標(biāo)簽(或者多個(gè)相同標(biāo)簽(比如多個(gè)div))時(shí),如果你需要返回所有的元素,請使用 querySelectorAll() 方法替代。
該方法返回所有滿足條件的元素,結(jié)果是個(gè)nodeList集合。查找規(guī)則與前面所述一樣。 ---->querySelectorAll 得到一個(gè)偽數(shù)組 DOM。
ParentNode.querySelectorAll()的結(jié)果是NodeList數(shù)組,但是又不是一般的js數(shù)組(Array),所以也不能直接調(diào)用Array的方法
<div id="box"> <ul> <li data->tagname 111</li> <li class="surfaces">這是clase? 222</li> <li class="surfaces">這是class333</li> <li class="surfaces" data->這是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 標(biāo)簽 console.log('query'+query_id.innerHTML); // console.log('query'+query_class.innerHTML); 第一個(gè)222 console.log('query'+query_tagname.innerHTML); 第一個(gè)222 -------------------------------------------------------------------------- 1 var query = document.querySelector.bind(document); //單個(gè)的 var query_id=query('#box'); //dom id var query_class=query('.surfaces'); // dom class var query_tagname=query('li') //dom 標(biāo)簽 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(); });
總結(jié)
到此這篇關(guān)于js中document.querySelector()方法的文章就介紹到這了,更多相關(guān)js中document.querySelector()方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
微信小程序控制臺提示warning:Now you can provide attr "wx:key" for a "w
這篇文章主要介紹了微信小程序控制臺提示warning:Now you can provide attr "wx:key" for a "wx:for" to improve performance解決方法,簡單分析了wx:for警告提示相關(guān)解決方法,需要的朋友可以參考下2019-02-02使用requirejs模塊化開發(fā)多頁面一個(gè)入口js的使用方式
這篇文章主要介紹了使用requirejs模塊化開發(fā)多頁面一個(gè)入口js的使用方式,需要的朋友可以參考下2017-06-06使用Javascript在HTML中顯示實(shí)時(shí)時(shí)間
這篇文章主要為大家詳細(xì)介紹了使用Javascript在HTML中顯示實(shí)時(shí)時(shí)間,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06總結(jié)分享10個(gè)JavaScript代碼優(yōu)化小tips
這篇文章主要介紹了總結(jié)分享10個(gè)JavaScript代碼優(yōu)化小tips,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07