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()可以直接加點擊事件,而querySelectorAll()不能直接加點擊事件
2、querySelector()
var node = document.querySelector(“#lover”); // 獲取文檔中的第一個id=lover的元素 var node = document.querySelector(“.lover”); // 獲取文檔中的第一個class=“l(fā)over"的元素 var node = document.querySelector(“p.lover”); // 獲取class=“l(fā)over” 的第一個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元素添加背景顏色,但是,如果文檔中
位于元素之前,元素將會被設置指定的背景顏色,總結(jié),多元素選擇時,哪個先匹配就是誰咯,只有一個被選中。
querySelector() 方法僅僅返回匹配指定選擇器的第一個元素。
3、querySelectorAll
elementList = document.querySelectorAll(selectors);
elementList 是一個靜態(tài)的 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 的數(shù)量", li.length); for (let i = 0; i < li.length; i++) { li[i].textContent = i; } let t1 = window.performance.now(); console.log("耗時" + (t1 - t0) + "毫秒");
當頁面中出現(xiàn)多個相同class標簽(或者多個相同標簽(比如多個div))時,如果你需要返回所有的元素,請使用 querySelectorAll() 方法替代。
該方法返回所有滿足條件的元素,結(jié)果是個nodeList集合。查找規(guī)則與前面所述一樣。 ---->querySelectorAll 得到一個偽數(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 標簽 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(); });
總結(jié)
到此這篇關于js中document.querySelector()方法的文章就介紹到這了,更多相關js中document.querySelector()方法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
微信小程序控制臺提示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警告提示相關解決方法,需要的朋友可以參考下2019-02-02使用requirejs模塊化開發(fā)多頁面一個入口js的使用方式
這篇文章主要介紹了使用requirejs模塊化開發(fā)多頁面一個入口js的使用方式,需要的朋友可以參考下2017-06-06總結(jié)分享10個JavaScript代碼優(yōu)化小tips
這篇文章主要介紹了總結(jié)分享10個JavaScript代碼優(yōu)化小tips,文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下2022-07-07