html5自动生成目录,JavaScript:自动生成博文目录导航

html5自动生成目录,JavaScript:自动生成博文目录导航感谢孤傲苍狼分享了自动生成博文目录的方法,本文仅作存档使用。图1:效果预览CSS样式#TOCbar{font-size:12px;text-align:left;position:fixed;auto;height:auto;top:50px;right:0px;/*离页面顶部与右侧的距离*/}#TOCbarTab{float:left;30px;border:1px…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

感谢 孤傲苍狼 分享了 自动生成博文目录的方法,本文仅作存档使用。

9a756ef48b35d04e5020950f8a0ba90e.png

图 1:效果预览

CSS 样式

#TOCbar{

font-size:12px; text-align:left; position:fixed; auto;

height: auto; top:50px; right:0px; /*离页面顶部与右侧的距离*/

}

#TOCbarTab{

float:left; 30px; border:1px solid #e5e5e5; border-right:none;

text-align:center; background:#ffffff;

}

#TOCbarContents{

float:left; overflow:auto; overflow-x:hidden;!important;

200px; min-height:123px; max-height:289px;

border:1px solid #e5e5e5; border-right:none; background:#ffffff;

}

#TOCbarContents dl{ margin:0; padding:0; }

#TOCbarContents dt{ margin-top:5px; margin-left:5px; }

#TOCbarContents dd, dt { cursor: pointer; }

#TOCbarContents dd:hover, dt:hover { color:#A7995A;}

Javascript 源码

var BlogDirectory = {

/*

获取元素位置,距浏览器左边界的距离(left)和距浏览器上边界的距离(top)

*/

getElementPosition:function (ele) {

var topPosition = 0;

var leftPosition = 0;

while (ele){

topPosition += ele.offsetTop;

leftPosition += ele.offsetLeft;

ele = ele.offsetParent;

}

return {top:topPosition, left:leftPosition};

},

/*

获取滚动条当前位置

*/

getScrollBarPosition:function () {

var scrollBarPosition = document.body.scrollTop || document.documentElement.scrollTop;

return scrollBarPosition;

},

/*

移动滚动条,finalPos 为目的位置,internal 为移动速度

*/

moveScrollBar:function(finalpos, interval) {

// 若不支持此方法,则退出

if(!window.scrollTo) {

return false;

}

// 窗体滚动时,禁用鼠标滚轮

window.onmousewheel = function(){

return false;

};

// 清除计时

if (document.body.movement) {

clearTimeout(document.body.movement);

}

var currentpos =BlogDirectory.getScrollBarPosition(); // 获取滚动条当前位置

var dist = 0;

if (currentpos == finalpos) { // 到达预定位置,则解禁鼠标滚轮,并退出

window.onmousewheel = function(){

return true;

}

return true;

}

if (currentpos < finalpos) { // 未到达,则计算下一步所要移动的距离

dist = Math.ceil((finalpos – currentpos)/10);

currentpos += dist;

}

if (currentpos > finalpos) {

dist = Math.ceil((currentpos – finalpos)/10);

currentpos -= dist;

}

var scrTop = BlogDirectory.getScrollBarPosition(); // 获取滚动条当前位置

window.scrollTo(0, currentpos); // 移动窗口

if(BlogDirectory.getScrollBarPosition() == scrTop) // 若已到底部,则解禁鼠标滚轮,并退出

{

window.onmousewheel = function(){

return true;

}

return true;

}

// 进行下一步移动

var repeat = “BlogDirectory.moveScrollBar(” + finalpos + “,” + interval + “)”;

document.body.movement = setTimeout(repeat, interval);

},

htmlDecode:function (text){

var temp = document.createElement(“div”);

temp.innerHTML = text;

var output = temp.innerText || temp.textContent;

temp = null;

return output;

},

/*

创建博客目录,id表示包含博文正文的 div 容器的 id,mt 和 st 分别表示主标题和次级标题的标签名称,interval 表示移动的速度

*/

createBlogDirectory:function (id, mt, st, interval){

// 获取博文正文div容器

var elem = document.getElementById(id);

if(!elem) return false;

// 获取div中所有元素结点

var nodes = elem.getElementsByTagName(“*”);

// 创建博客目录的div容器

var divTOCbar = document.createElement(‘DIV’);

divTOCbar.className = ‘TOCbar’;

divTOCbar.setAttribute(‘id’, ‘TOCbar’);

var divTOCbarTab = document.createElement(‘DIV’);

divTOCbarTab.setAttribute(‘id’, ‘TOCbarTab’);

divTOCbar.appendChild(divTOCbarTab);

var h3 = document.createElement(‘h3’);

divTOCbarTab.appendChild(h3);

var txt = document.createTextNode(‘<

h3.appendChild(txt);

var divTOCbarContents = document.createElement(‘DIV’);

divTOCbarContents.style.display = ‘none’;

divTOCbarContents.setAttribute(‘id’, ‘TOCbarContents’);

divTOCbar.appendChild(divTOCbarContents);

// 创建自定义列表

var dlist = document.createElement(“dl”);

divTOCbarContents.appendChild(dlist);

var num = 0; // 统计找到的mt和st

mt = mt.toUpperCase(); // 转化成大写

st = st.toUpperCase(); // 转化成大写

// 遍历所有元素结点

for(var i=0; i

{

if(nodes[i].nodeName == mt|| nodes[i].nodeName == st)

{

// 获取标题文本

var nodetext = nodes[i].innerHTML.replace(/?[^>]+>/g,””); // innerHTML里面的内容可能有HTML标签,所以用正则表达式去除HTML的标签

nodetext = nodetext.replace(/ /ig, “”); // 替换掉所有的  

nodetext = BlogDirectory.htmlDecode(nodetext);

// 插入锚

nodes[i].setAttribute(“id”, “blogTitle” + num);

var item;

switch(nodes[i].nodeName)

{

case mt: // 若为主标题

item = document.createElement(“dt”);

break;

case st: // 若为子标题

item = document.createElement(“dd”);

break;

}

// 创建锚链接

var itemtext = document.createTextNode(nodetext);

item.appendChild(itemtext);

item.setAttribute(“name”, num);

item.onclick = function(){ // 添加鼠标点击触发函数

var pos = BlogDirectory.getElementPosition(document.getElementById(“blogTitle” + this.getAttribute(“name”)));

if(!BlogDirectory.moveScrollBar(pos.top, interval)) return false;

};

// 将自定义表项加入自定义列表中

dlist.appendChild(item);

num++;

}

}

if(num == 0) return false;

/* 鼠标进入时的事件处理 */

divTOCbarTab.onmouseenter = function(){

divTOCbarContents.style.display = ‘block’;

}

/* 鼠标离开时的事件处理 */

divTOCbar.onmouseleave = function() {

divTOCbarContents.style.display = ‘none’;

}

document.body.appendChild(divTOCbar);

}

};

window.οnlοad=function(){

/* 页面加载完成之后生成博客目录 */

BlogDirectory.createBlogDirectory(“cnblogs_post_body”,”h1″,”h2″,20);

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/214259.html原文链接:https://javaforall.net

(0)
上一篇 2025年7月16日 下午12:43
下一篇 2025年7月16日 下午1:15


相关推荐

  • 韦伯分布(威布尔分布,Weibull distribution)

    韦伯分布(威布尔分布,Weibull distribution)韦伯分布 Weibulldistr 一般用来统计可靠性或寿命检验时用 例如 预计在有效寿命阶段有多少次保修索赔 预计将在 8 小时老化期间失效的保险丝占多大百分比 在管理科学与工程领域 见到一些学者假定产品的需求为韦伯分布 因为正态分布或者泊松分布过于理想化 韦伯分布相对来说更接近现实一些 韦伯分布的概率密度函数为 f x k k x k 1e x kx

    2026年3月26日
    2
  • jstorm 使用demo

    jstorm 使用demo结合 fieldsGroupi 分组模式的一个 jstorm 使用实例 指定分组模式可以保证被指定的字段 如果相同值则 tuple 会分配给同个 task 处理 例如一个 tuple 有两个字段 field1 field2 如果指定 field1 为分组字段 现在有两个 tuple 分别是 tuple1 tuple2 tuple1 中 filed1 值为 a filed2 值为 b tuple2 的 filed1 值为 a filed2 值

    2026年3月16日
    2
  • 即梦图片4.0来了,我整理了10个好用到爆的进阶玩法。

    即梦图片4.0来了,我整理了10个好用到爆的进阶玩法。

    2026年3月12日
    2
  • python动态心形代码简单_python 心形

    python动态心形代码简单_python 心形0.最终效果1.绘制一条心形曲线最近看到个视频,打算绘制个心型动态的曲线。1.1Matlab确定图像及其函数网上有很多关于心形曲线的资料,各种各样的形状,但是我比较倾心于桃心形。先在Matlab里简单看一下是什么样的。桃心形曲线的方程如下x=16sin^3(t)y=13cos(t)-5cos(2t)-2cos(3t)-cos(4t)Matlab绘制效果如下:Matlab程序如下。clcc…

    2026年4月13日
    4
  • 矢量控制——SVPWM

    矢量控制——SVPWM空间矢量脉宽调制 SVPWM 主要思想是把三相交流电机等效为直流电机 然后跟踪圆形磁场 SVPWM 主要由 波形发生器 Chark 变换 扇区判断 Park 变换 桥臂作用时间 比较器 插入死区等模块组成 1 波形发生器 使用 DDS 在 FPGA 内部产生正弦波 三角波 如果是三相星形不带零线 则可以只产生两路正弦波 相位相差 120 度 相位差可以在 DDS 的地址加个常数来实现 三角波 则

    2026年3月18日
    3
  • 一维条形码识别的整个过程原理通俗易懂讲解

    一维条形码识别的整个过程原理通俗易懂讲解这里我随便在我的编译原理这本书后面拍的一个条形码来进行说明以下为一个示意图 一维条形码一共有如下几个区域组成 其实一个条形码下面已经给出了代表哪些数字了 我写的这篇文章讲述其原理 教机器如何读取 首先明白如下几点 一 条码的黑色条表示二进制的 1 白色代表 0 而且 0 33mm 宽度的黑色或者白色条为一个基本的二进制位 下面可以看出有的黑色条很宽 说明连着好几个二进制 1

    2026年3月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号