博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
博客内容进度插件的实现
阅读量:7043 次
发布时间:2019-06-28

本文共 2746 字,大约阅读时间需要 9 分钟。

前面的话

  最近在复习自己写的博客,但有的博客内容很长,长到不知道多少时间可以读完。这时,就有种泄气的冲动。但,如果能够提供一个博客内容进度的插件,根据所读内容的多少,显示进度条,让自己对所读的内容进度心里有数,可以让自己平静下来,一点一点读下去。本文将详细介绍博客内容进度插件的实现

 

效果演示

  无论是通过鼠标滚轮,还是拖动滚动条,也或者是按空格键,只要发生了页面的滚动操作,就会触发页面底部博客内容进度条的变化。根据当前内容的多少计算与博客所有内容的比例,最终对应成进度条的宽度。当鼠标移入进度条范围时,会以数字显示出当前的进度百分比

  通过使用如下代码,可将进度插件插入页面中

   由于目录和进度都是常用的功能,所以,我把进度的功能整合到的插件中了

 

原理解释

  上面已经简明扼要的说明了进度条的原理,而实现起来也不困难。在触发滚动事件时,计算两个高度值。一个值H用来表示整篇博客内容的底部离页面顶端的距离。一个值h用来表示当前窗口内博客内容的底部离页面顶端的距离。从而比例值radio = h/H,就是进度百分比,以进度条的宽度变化显示出来

 

具体实现

  【1】获取博客内容总高度H,如下图所知,博客园将博客内容放在id为cnblogs_post_body的div内,通过scrollHeight来获取其高度即可。且该值是固定不变的,不需在发生滚动事件时再获取,页面加载完成后就可获取

function addEvent(target,type,handler){    if(target.addEventListener){        target.addEventListener(type,handler,false);    }else{        target.attachEvent('on'+type,function(event){            return handler.call(target,event);        });    }}var H;addEvent(window,'load',function(){    H = cnblogs_post_body.scrollHeight;});

  【2】获取当前页面窗口中显示的博客内容高度h,h实际上就是页面的滚动距离h2

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

  【3】进度条实现,通过H和h,可以计算出比例系数radio = h/H。HTML5新增了一个表单类控件progress,就是用来表示任务的进度或进程的

  [注意]IE9-浏览器不支持

  如果是IE9-浏览器,progress元素被退化为div元素,仅显示百分比即可

  将progress的max值设置为H,将value值设置为h。滚动事件触发时,更新value值即可

addEvent(window,'scroll',function(){    var h = document.documentElement.scrollTop || document.body.scrollTop;    progress.value =  h;    var radio = (h/H >= 1) ? 1 : h/H;    progress.innerHTML = progress.title =  Math.floor(100*radio) + '%';    });

  【4】样式设置

  进度条的样式设置较为简单,将其固定定位,居于页面底部,并与窗口宽度相同

.progress{    position:fixed;    left:0;    right:0;    bottom:0;    width:100%;    height:12px;    text-align:center;    font:12px/12px "宋体";}

  【5】动态脚本

  由于最终将以插件的形式呈现,所有的代码都需要动态生成

var progress = document.createElement('progress');progress.id = 'progress';document.body.appendChild(progress);

 

插件代码

//事件兼容function addEvent(target,type,handler){    if(target.addEventListener){        target.addEventListener(type,handler,false);    }else{        target.attachEvent('on'+type,function(event){            return handler.call(target,event);        });    }}//生成元素var progress = document.createElement('progress');progress.id = 'progress';progress.style.cssText = 'position:fixed;left:0;right:0;bottom:0;width:100%;height:12px;text-align:center;font:12px/12px "宋体";';document.body.appendChild(progress);//计算Hvar H;addEvent(window,'load',function(){    progress.max = H = cnblogs_post_body.scrollHeight;});//计算h及radioaddEvent(window,'scroll',function(){    var h = document.documentElement.scrollTop || document.body.scrollTop;    progress.value =  h;    var radio = (h/H >= 1) ? 1 : h/H;    progress.innerHTML = progress.title =  Math.floor(100*radio) + '%';    });

转载于:https://www.cnblogs.com/zhaolizhe/p/6953970.html

你可能感兴趣的文章
Android的资源管理器的创建过程
查看>>
php验证身份证函数
查看>>
[使用 Weex 和 Vue 开发原生应用] 1 如何配置开发环境
查看>>
红帽发布 Ansible Tower 3.4:在混合云中实践DevOps更便捷
查看>>
Linus 发文宣布Linux Kernel 5.0 正式发布
查看>>
定制你的敏捷方法:以结果为导向
查看>>
关于Visual Studio 2019的前期详情
查看>>
PWA即将推向所有Chrome平台
查看>>
官宣!微软宣布桌面版 Edge将基于Chromium进行开发\n
查看>>
运用供应链管理实现更快速、更高质量的交付
查看>>
3·15曝光丨智能机器人一年拨打40亿个骚扰电话,6亿人信息已遭泄露!
查看>>
ASP.NET Core 2.1带来SignalR、Razor类库
查看>>
敏捷2016大会主题演讲:现代敏捷
查看>>
经典Java面试题解析——谈谈你对Java平台的理解?
查看>>
从对敏捷的“船货崇拜”到成为敏捷组织
查看>>
WebAssembly Studio:Mozilla提供的WASM工具
查看>>
Visual Studio 15改进C++工程加载
查看>>
雷军定AI+IoT为小米核心战略,牵手宜家推进生态布局
查看>>
移动开发的罗曼蒂克消亡史
查看>>
独家解读 | 滴滴机器学习平台架构演进之路
查看>>