博客内容进度插件的实现

前面的话

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

 

效果演示

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

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

<script src="http://files.cnblogs.com/files/xiaohuochai/progress.js"></script>

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

<script src="http://files.cnblogs.com/files/xiaohuochai/catalog.js"></script>

 

原理解释

  上面已经简明扼要的说明了进度条的原理,而实现起来也不困难。在触发滚动事件时,计算两个高度值。一个值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-浏览器不支持

<progress id="progress" value="" max=""></progress>

  如果是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);

//计算H
var H;
addEvent(window,'load',function(){
    progress.max = H = cnblogs_post_body.scrollHeight;
});

//计算h及radio
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) + '%';    
});
复制代码
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
雨燕网站信息发布系统基于javaweb(jsp)技术搭建而成,数据库采用SQLServer2008,开发环境MyEclipse8.0,部署环境用TOMCAT6.0(JDK1.6)。本系统部署包完全免费公开,适合于网站后台程序设计人员及网页编程爱好者学习使用。 部署方法: 1、通过http://ewb.phome100.com/ewb/Login.jsp获取程序包。 2、解压程序包,在ewb目录下找到\databak\CmsDatadb.bak数据库备份文件进行数据库还原。 3、将ewb文件夹拷贝到tomcat\webapps下。 4、重新启动TOMCAT服务,通过http://您的访问路径/ewb/Cms_Admin/Login.jsp进行访问,完成程序部署。 系统功能: 1、网站管理员模块:由单位模块、角色模块、用户模块三部份组成,适合于多操作员多部门网站管理人员权限划分的需要,操作顺序:先增加单位、再建立角色,等单位与角色创建成功后再开设管理员账号,因为管理员账号是建立在单位与角色的基础上。 2、信息发布:信息发布是本系统一大亮点,针对不同角色不同单位信息各自发布权限的控制设计的,分维护性发布与审核性发布,对于一般无需审核的信息可直接通过具有维护权限的管理直接发布,对于需要审核的信息发布,则是通过审核性发布流程来实现,审核分为两级审核,初审与复审,初审与复审不互斥,在初审阶段合格信息可不经复审直接发布。 3、其它功能:主要包括,网站栏目管理、IP统计访问、网站弹窗与飘窗等。 演示地址: http://ewb.xibusb.com/ewb/Cms_Admin/Login.jsp 用户名:admin 密码:admin
使用故事点,项目和进度条对Trello板进行超级充值 Trello主板的敏捷SCRUM通过启用SCRUM功能为您的Trello主板提供超强的功能: ★故事点:设置Trello卡的故事点 ★时间消耗:设定花费在任务上的时间。 ★标签:将卡片分组成标签,用户故事或项目,这些都是自动着色,以节省您的时间。 ★进度条:立即显示您的Sprint进度,并在卡片和列表上显示简洁的背景进度条。 ★HEADER SEPARATORS:使用标题分隔符将列表中的卡片分组。 ★视觉艾滋病:有更多故事点数的卡片的字体大小略有增加,所以你可以一目了然地从更小的任务中区分出更大的卡片。 说明 ------------------- 没有必要设置任何东西!这个扩展是简单的,安装它,并开始给你的Trello超级大国。 通过在括号中输入数字将故事点添加到卡上: (3)设计新的主页标题“ 跟踪每张卡上的时间: “(1/3)设计新的主页标题” 通过在方形的布局中写入一张卡片给一个项目: “[dev]在页脚实施广告” 通过在开始和结束处创建一个带有三个星号的新卡创建一个标题分隔符: “*** Sprint 3 ***” 您可以根据需要添加尽可能多的标签。标签将以随机颜色自动着色。 故事点和标签都可以在卡的文本中的任何位置定义,通常最好在开始时添加它们,以便阅读。 在列表和卡片的右上角,你可以看到已经完成了多少个故事点以及总共有多少个故事点。 兼容性 ------------------- 如果团队成员没有安装“敏捷SCRUM for Trello板卡”扩展程序,他仍然可以看到故事点和项目以及修改它们(他不会看到颜色或进度条)。您可以随时安装/卸载扩展程序,而不会丢失任何数据。 “Trello主板的敏捷SCRUM”是速度最快,性能最好的所有类似扩展程序,只需2KB代码即可安装,即使是慢速计算机或需要Chrome浏览器快速工作的用户由于有太多的扩展,这个扩展有这样一个微不足道的小脚印。 链接和资源 ------------------- - 源代码:https://github.com/luckyshot/agilescrumfortrello - 问题跟踪:https://github.com/luckyshot/agilescrumfortrello/issues - 博客文章+截图:http://xaviesteve.com/5109/agile-scrum-trello-boards/ 更新日志 ------------------- ★1.4.3 - 修复了不能检测到长度超过3个字符(0 / 10.5)的故事点的问题 - 改进了检测变化和渲染电路板的方法 ★1.4.2 - 根据GPL许可证发布的源代码https://github.com/luckyshot/agilescrumfortrello - 您可以在标签内添加“#”符号 - 删除设置按钮(尚未完成) ★1.4.1 - 圆角故事指向一位小数 ★1.4.0 - 巨大的重构,以获得更好的可扩展性和新功能和反馈的未来发展 - 当故事点数超出时,则以略微的红色显示,当估计完美后,以浅绿色显示 - 改进更新侦听器,以获得更好的性能,响应能力和更少的内存消耗 ★1.3.5 - 修正了'nullHTML / undefined'错误 - 标签颜色的随机性增加 - 更新了从2.1.1到2.1.4的jQuery ★1.3.4 - 修正:标签支持“。” (点) ★1.3.3 - 修正:进度条似乎不适用于主题背景 ★1.3.2 - 修正无限小数位错误 ★1.3.1 - 不记得,也许是很棒的东西 ★1.3.0 - 标题分隔符现在计算其中的任务的故事点,所以你可以在每个列表中有子组(我用它在季度列表中有存档的Sprint) - 更好的标记着色(总是很好的光滑的颜色!) - 增加进度栏透明度,以提高可读性 ★1.2.5 - 修正了当连字符发现时不会显示标题分隔符的问题 ★1.2.4 - 标题分隔符 ★1.2.3 - 修正了添加新卡时扩展有时会停止工作的错误 ★1.2.2 - 进度条着色作为电路板背景的阴影 - 设计改进 - 修正了在某些情况下Progress Bard不能正确更新的错误 ★1.2.1 - 改进的文档 - 代码优化 ★1.2.0 - 更快,更小的代码,实现卓越的性能和极小的占用空间 - 从扩展包中删除不必要的文件20% ★1.1.7 - 根据故事点自动增加卡的字体大小 - 代码优化和性能 - 编码的OOP设计模式 ★1.1.6 - 增加了对Google Chrome商店的扩展 - Bug修复 支持语言:English

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值