使用JS獲取頁面上的所有標(biāo)簽
最近忙的一匹,忙著大保健,都來不及寫博客,今天特意抽出點(diǎn)時(shí)間來寫一寫
前兩天看到一個(gè)題,是問如何從頁面上獲取所有的標(biāo)簽的并查看他們的數(shù)量,感覺還是有點(diǎn)意思的,所以給大家來搞一下子
我們先來捋捋思路,那要從頁面上獲取標(biāo)簽,不用說我們肯定會(huì)想到DOM操作,那獲取到了之后呢,我們又不確定某個(gè)元素有沒有子元素,那怎么辦呢,這個(gè)時(shí)候我們肯定會(huì)想到遞歸啊
那現(xiàn)在我們有了DOM操作和遞歸就好辦了,就可以直接寫代碼了,下面是代碼,寫了注釋,大家可以拉下去參考一下
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<ul></ul>
</body>
</html>
<script>
var map = {};
//采用遞歸調(diào)用的方法,比較方便和簡單。
function fds(node) {
if (node.nodeType === 1) {
//這里我們用nodeName屬性,直接獲取節(jié)點(diǎn)的節(jié)點(diǎn)名稱
var tagName = node.nodeName;
//判斷對(duì)象中存在不存在同類的節(jié)點(diǎn),若存在則添加,不存在則添加并賦值為1
map[tagName] = map[tagName] ? map[tagName] + 1 : 1;
}
//獲取該元素節(jié)點(diǎn)的所有子節(jié)點(diǎn)
var children = node.childNodes;
for (var i = 0; i < children.length; i++) {
//遞歸調(diào)用
fds(children[i])
}
}
fds(document);
console.log(map)
</script>
總結(jié)
以上所述是小編給大家介紹的使用JS獲取頁面上的所有標(biāo)簽,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- Angular.js中ng-include用法及多標(biāo)簽頁面的實(shí)現(xiàn)方式詳解
- 在JS中a標(biāo)簽加入單擊事件屏蔽href跳轉(zhuǎn)頁面
- AngularJs頁面篩選標(biāo)簽小功能
- JS檢測(cè)頁面中哪個(gè)HTML標(biāo)簽觸發(fā)點(diǎn)擊事件的方法
- JavaScript獲得頁面base標(biāo)簽中url的方法
- jsp頁面中如何將時(shí)間戳字符串格式化為時(shí)間標(biāo)簽
- 實(shí)現(xiàn)網(wǎng)頁頁面跳轉(zhuǎn)的幾種方法(meta標(biāo)簽、js實(shí)現(xiàn)、php實(shí)現(xiàn))
- JSP頁面中如何用select標(biāo)簽實(shí)現(xiàn)級(jí)聯(lián)
- javascript標(biāo)簽在頁面中的位置探討
- 一個(gè)js隨機(jī)顏色腳本(用于標(biāo)簽頁面,也可用于任何頁面)
相關(guān)文章
js 剪切板應(yīng)用clipboardData詳細(xì)解析
本篇文章主要介紹了js剪切板應(yīng)用clipboardData。需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-12-12
JavaScript的9個(gè)陷阱及評(píng)點(diǎn)分析
以下是JavaScript容易犯錯(cuò)的九個(gè)陷阱。雖然不是什么很高深的技術(shù)問題,但注意一下,會(huì)使您的編程輕松些,即所謂make life easier. 筆者對(duì)某些陷阱會(huì)混雜一些評(píng)點(diǎn)。2008-05-05
JavaScript時(shí)間轉(zhuǎn)換處理函數(shù)
這篇文章主要介紹了JavaScript時(shí)間轉(zhuǎn)換處理函數(shù)的方法的相關(guān)資料,需要的朋友可以參考下2015-04-04
使用JavaScript實(shí)現(xiàn)檢測(cè)網(wǎng)頁是否為空閑狀態(tài)
最近開發(fā)項(xiàng)目時(shí),常碰到“用戶在一定時(shí)間內(nèi)無任何操作時(shí),跳轉(zhuǎn)到某個(gè)頁面”的需求,所以本文就來使用JavaScript實(shí)現(xiàn)這一要求,需要的可以參考下2024-03-03
解讀input標(biāo)簽的value屬性及name屬性
這篇文章主要介紹了解讀input標(biāo)簽的value屬性,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
JS實(shí)現(xiàn)數(shù)組內(nèi)值累加常見的3個(gè)方法
這篇文章主要給大家介紹了關(guān)于JS實(shí)現(xiàn)數(shù)組內(nèi)值累加常見的3個(gè)方法,文中通過實(shí)例代碼將3個(gè)方法介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用js具有一定參考借鑒價(jià)值,需要的朋友可以參考下2023-07-07

