国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

利用原生JS自動(dòng)生成文章標(biāo)題樹的實(shí)例

2019-11-20 09:10:52
字體:
供稿:網(wǎng)友

實(shí)現(xiàn)原理很簡單,就是循環(huán)文章模塊,并抽取其中的h2、h3標(biāo)簽,將其中的內(nèi)容賦予給新建的title樹。

代碼如下:

HTML代碼:

<div class="contextBox"> <div id="article">  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <p>hello hello hello hello hello hello hello hello hello hello hello hello</p>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <p>hello hello hello hello hello hello hello hello hello hello hello</p>  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <p>world world world world world world world world world world world world world world world world world world world world world world world world world world world world world world world </p>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3> </div> <div class="articleMenu-box" id="articleMenu_box">  <span class="articleMenu-open" id="articleMenu_open"></span>  <ul class="articleMenu hello" id="articleMenu">   <span class="articleMenu-close" id="articleMenu_close"></span>  </ul> </div></div>

CSS代碼:

* { margin: 0; padding: 0; border: 0;}body { font: 16px/1.5;}ul li, ol li { list-style: none;}.contextBox { position: relative; width: 960px; margin: 0 auto;}#article { margin-left: 200px; border: 1px #eee solid; padding: 15px;}.articleMenu a { text-decoration: none; color: #333;}.articleMenu a:hover { color: #f85455;}.articleMenu-box { width: 170px; position: absolute; left: 10px; top: 10px;}.articleMenu { padding: 10px; border: 1px solid #ccc; box-shadow: 2px 2px 2px #eee;}.titleH2, .titleH3 { line-height: 1.5em;}.titleH2 { font-weight: bold;}.titleH3 { margin-left: 20px;}.articleMenu .articleMenu-close, .articleMenu-open { display: inline-block; position: absolute; right: 0; top: 0; height: 44px; width: 44px; cursor: pointer;}.articleMenu-open { background: url("http://www.dengzhr.com/wp-content/themes/dengzhr/images/icon_articleMenu_open.png") no-repeat 50% 50%; display: none;}.articleMenu .articleMenu-close { background: url("http://www.dengzhr.com/wp-content/themes/dengzhr/images/icon_articleMenu_close.png") no-repeat 50% 50%;}

JavaScript代碼:

var article = document.getElementById("article");var articleHgroupMenu = document.getElementById("articleMenu");// 關(guān)閉和展開文檔樹var articleMenu_open = document.getElementById("articleMenu_open");var articleMenu_close = document.getElementById("articleMenu_close");articleMenu_close.onclick = function() { articleHgroupMenu.style.display = "none"; articleMenu_open.style.display = "block";};articleMenu_open.onclick = function() { articleHgroupMenu.style.display = "block"; articleMenu_open.style.display = "none";};//titleHgroup(article, articleHgroupMenu, "titleH2", "titleH3");// 獲得obj下的直接子元素中為標(biāo)題h2~h3的標(biāo)題元素// 參數(shù)說明:hgroupParent為包含h2和h3的直接父元素;MenuList為承載新建文章列表的ul元素;// h2ClassName、h3ClassName分別為新建文章列表中對應(yīng)h2、h3的li自列表的Class屬性;function titleHgroup(hgroupParent, MenuList, h2ClassName, h3ClassName) { var hgroup = hgroupParent.children; // 創(chuàng)建文檔片段,來包裹自動(dòng)生成的h2、h3對應(yīng)生成的li列表 var fragment = document.createDocumentFragment(); for(i = 0; i < hgroup.length && hgroup[i].nodeType === 1; i++) {  // 為對應(yīng)類型的標(biāo)題生成li列表  // 參數(shù)說明:hType為標(biāo)題的類型如h1~h6;className為標(biāo)題對應(yīng)的li列表的class屬性值;  function titleToList(hType, className) {   var li = document.createElement("li");   li.className = className;   // 為li標(biāo)簽內(nèi)部添加a標(biāo)簽,用錨點(diǎn)進(jìn)行定位;   hgroup[i].id= hType + i;   li.innerHTML = ("<a href='#" + hType + i + "'>" + hgroup[i].innerHTML +"</a>");   fragment.appendChild(li);  }  // 當(dāng)遍歷中標(biāo)題元素為h2時(shí),調(diào)用titleToList(hType, className)新增對應(yīng)的li列表;  if(hgroup[i].nodeName.toLowerCase() == "h2") {   titleToList("h2", h2ClassName);  }  // 當(dāng)遍歷中標(biāo)題元素為h3時(shí),調(diào)用titleToList(hType, className)新增對應(yīng)的li列表;  if(hgroup[i].nodeName.toLowerCase() == "h3") {   titleToList("h3", h3ClassName);  } } // 將承載好對應(yīng)li元素集合的文檔片段fragment添加到DOM(即在DOM中包裹li列表的父元素)中去; MenuList.appendChild(fragment);}

完整實(shí)例代碼

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=gb2312" /><title>原生JS實(shí)現(xiàn)自動(dòng)生成文章標(biāo)題樹</title><style type="text/css">* { margin: 0; padding: 0; border: 0;}body { font: 16px/1.5;}ul li, ol li { list-style: none;}.contextBox { position: relative; width: 960px; margin: 0 auto;}#article { margin-left: 200px; border: 1px #eee solid; padding: 15px;}.articleMenu a { text-decoration: none; color: #333;}.articleMenu a:hover { color: #f85455;}.articleMenu-box { width: 170px; position: absolute; left: 10px; top: 10px;}.articleMenu { padding: 10px; border: 1px solid #ccc; box-shadow: 2px 2px 2px #eee;}.titleH2, .titleH3 { line-height: 1.5em;}.titleH2 { font-weight: bold;}.titleH3 { margin-left: 20px;}.articleMenu .articleMenu-close, .articleMenu-open { display: inline-block; position: absolute; right: 0; top: 0; height: 44px; width: 44px; cursor: pointer;}.articleMenu-open { background: url("http://www.dengzhr.com/wp-content/themes/dengzhr/images/icon_articleMenu_open.png") no-repeat 50% 50%; display: none;}.articleMenu .articleMenu-close { background: url("http://www.dengzhr.com/wp-content/themes/dengzhr/images/icon_articleMenu_close.png") no-repeat 50% 50%;}</style></head><body><div class="contextBox"> <div id="article">  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <p>hello<br /> hello<br /> hello<br /> hello<br /> hello<br /> hello<br /><br /> hello<br /> hell<br />o hel<br />lo hell<br />o he<br />llo hello</p>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <p>hello hello hello hello hello hello hello hello hello hello hello</p>  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <p>world w<br />orld <br />world world wo<br />rld world wo<br />rld world world wor<br />ld world world <br />world <br />worl<br />d world<br /> w<br />orld <br />world wo<br />rld wor<br />ld world wor<br />ld world worl<br />d w<br />or<br />ld<br /> <br />world <br />world <br />world<br /> <br />wo<br />rld wo<br />rld w<br />orld w<br />orld </p>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3>  <h2>二級標(biāo)題</h2>  <h3>三級標(biāo)題</h3>  <h3>三級標(biāo)題</h3> </div> <div class="articleMenu-box" id="articleMenu_box">  <span class="articleMenu-open" id="articleMenu_open"></span>  <ul class="articleMenu hello" id="articleMenu">   <span class="articleMenu-close" id="articleMenu_close"></span>  </ul> </div></div><script type="text/javascript">var article = document.getElementById("article");var articleHgroupMenu = document.getElementById("articleMenu");// 關(guān)閉和展開文檔樹var articleMenu_open = document.getElementById("articleMenu_open");var articleMenu_close = document.getElementById("articleMenu_close");articleMenu_close.onclick = function() { articleHgroupMenu.style.display = "none"; articleMenu_open.style.display = "block";};articleMenu_open.onclick = function() { articleHgroupMenu.style.display = "block"; articleMenu_open.style.display = "none";};//titleHgroup(article, articleHgroupMenu, "titleH2", "titleH3");// 獲得obj下的直接子元素中為標(biāo)題h2~h3的標(biāo)題元素// 參數(shù)說明:hgroupParent為包含h2和h3的直接父元素;MenuList為承載新建文章列表的ul元素;// h2ClassName、h3ClassName分別為新建文章列表中對應(yīng)h2、h3的li自列表的Class屬性;function titleHgroup(hgroupParent, MenuList, h2ClassName, h3ClassName) { var hgroup = hgroupParent.children; // 創(chuàng)建文檔片段,來包裹自動(dòng)生成的h2、h3對應(yīng)生成的li列表 var fragment = document.createDocumentFragment(); for(i = 0; i < hgroup.length && hgroup[i].nodeType === 1; i++) {  // 為對應(yīng)類型的標(biāo)題生成li列表  // 參數(shù)說明:hType為標(biāo)題的類型如h1~h6;className為標(biāo)題對應(yīng)的li列表的class屬性值;  function titleToList(hType, className) {   var li = document.createElement("li");   li.className = className;   // 為li標(biāo)簽內(nèi)部添加a標(biāo)簽,用錨點(diǎn)進(jìn)行定位;   hgroup[i].id= hType + i;   li.innerHTML = ("<a href='#" + hType + i + "'>" + hgroup[i].innerHTML +"</a>");   fragment.appendChild(li);  }  // 當(dāng)遍歷中標(biāo)題元素為h2時(shí),調(diào)用titleToList(hType, className)新增對應(yīng)的li列表;  if(hgroup[i].nodeName.toLowerCase() == "h2") {   titleToList("h2", h2ClassName);  }  // 當(dāng)遍歷中標(biāo)題元素為h3時(shí),調(diào)用titleToList(hType, className)新增對應(yīng)的li列表;  if(hgroup[i].nodeName.toLowerCase() == "h3") {   titleToList("h3", h3ClassName);  } } // 將承載好對應(yīng)li元素集合的文檔片段fragment添加到DOM(即在DOM中包裹li列表的父元素)中去; MenuList.appendChild(fragment);}</script></body></html>

總結(jié)

以上就是利用原生JS自動(dòng)生成文章標(biāo)題樹的全部內(nèi)容,希望本文的內(nèi)容對大家能有所幫助,如果有疑問可以留言討論。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 全州县| 平原县| 会泽县| 岳西县| 永川市| 上蔡县| 本溪市| 文昌市| 绥阳县| 孙吴县| 建始县| 焦作市| 泰宁县| 方正县| 衢州市| 政和县| 临沧市| 宜春市| 利川市| 安龙县| 黔南| 泊头市| 泌阳县| 汝阳县| 新和县| 孝义市| 财经| 通州区| 伊宁市| 兴仁县| 辉南县| 灵台县| 得荣县| 临海市| 平乐县| 织金县| 双牌县| 天峨县| 弥渡县| 萍乡市| 台北县|