博客内容进度插件的实现

前面的话

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

效果演示

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

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

<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) + ‘%‘;
});
时间: 2024-10-29 19:05:46

博客内容进度插件的实现的相关文章

Vue.js实践:一个Node.js+mongoDB+Vue.js的博客内容管理系统

项目来源 以前曾用过WordPress搭建自己的博客网站,但感觉WordPress很是臃肿.所以一直想自己写一个博客内容管理器. 正好近日看完了Vue各个插件的文档,就用着Vue尝试写了这个简约的博客内容管理器(CMS). 嗯,我想完成的功能: 一个基本的博客内容管理器功能,如后台登陆,发布并管理文章等 支持markdown语法实时编辑 支持代码高亮 管理博客页面的链接 博客页面对移动端适配优化 账户管理(修改密码) Demo 登陆后台按钮在页面最下方"站长登陆",可以以游客身份登入后

python爬虫爬取csdn博客专家所有博客内容

python爬虫爬取csdn博客专家所有博客内容: 全部过程采取自动识别与抓取,抓取结果是将一个博主的所有 文章存放在以其名字命名的文件内,代码如下 结果如下: 版权声明:本文为博主原创文章,未经博主允许不得转载.

这博客内容格式有点乱

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"     xmlns:tools="http://schemas.android.com/tools"     android:layout_width="match_parent"     android:layout_height="match_parent"     a

博客内容和格式整理想法

写文章可以帮助我们思考技术和项目的过程,从整体上总结自己的存在的优点和缺点,避免重复错误.但是博客切忌写成流水账,没有文章的结构和重点,看起来十分乏味,所以我这里总结不同博客类型的内容和博客书写应该注意点,希望在以后提高博客的可读性和逻辑性. 博客类型总结 好的博客需要明确的主题和内容,根据平常工作和学习的需要,通常将博客分成四类:A. 项目记录和总结 B.技术学习和扩展 C.问题解决方案 D.编程技巧.不同的博客类型记录要点不同. 写项目: 项目背景 自己在项目中的职责和完成度 使用技术和技术

提纲挈领-我的博客内容架构(持续更新)

有时候在想,如果通过一篇文章了解该博主的所有博客内容,于是想到了一个方式,就是“提纲挈领”自己整理一篇博客内容架构的说明,里面有相关文章的链接 类似一个总入口,通过这个入口,可以进入博客中所有内容,也就是有进入其他文章的每个入口,这样,通过一篇文章,就可以提纲挈领的管理和了解自己的博客 容易自己管理博客内容,也容易别人了解博客内容,这是一个初步的想法,后续会根据具体的实践,不断地优化 博客内容架构: 0系列-因为主攻网络空间安全方向,所以放在第一位 01-网络空间安全(学习) 02-网络空间安全

自定义博客园JS插件

在博客园侧边栏添加JS内容,需要先点击申请JS的链接. 1.动态钟表插件JS代码 <object classid="clsid:d27cdb6e-ae6d-11cf-96b8-444553540000" codebase="http://fpdownload.macromedia.com/pub/shockwave/cabs/flash/swflash.cab#version=8,0,0,0" width="160" height=&quo

网站seo必备:给你的wordpress博客添加sitemap插件

wordpress博客搭建以后,我就推荐安装两个插件,一个是WP-PostViews,详细可以查看<wordpress文章统计插件:WP-PostViews让你的文章阅读量及时更新>,另一个就是今天所说的sitemap插件. 今天分享的这个插件,可以同时生成sitemap.xml和sitemap.html.让你的网站更加利于seo,用户体验更好. 第一步.下载wordpress的sitemap插件,下载地址文末给出. 第二步.安装插件.后台--插件--安装插件--上传插件--选择文件--现在安

杨泽业:你的WordPress博客必备seo插件sitemap插件

wordpress博客搭建以后,我就推荐安装两个插件,一个是WP-PostViews,详细可以查看<wordpress文章统计插件:WP-PostViews让你的文章阅读量及时更新>,另一个就是今天所说的sitemap插件. 今天分享的这个插件,可以同时生成sitemap.xml和sitemap.html.让你的网站更加利于seo,用户体验更好. 第一步.下载wordpress的sitemap插件,下载地址文末给出. 第二步.安装插件.后台--插件--安装插件--上传插件--选择文件--现在安

Django从零搭建个人博客 | 使用allauth插件管理用户登录与注册

原文博客地址:http://www.eosones.com/ django-allauth是最受欢迎的管理用户登录与注册的第三方Django安装包,可以大大简化我们用户注册,登录及账户管理,其核心功能包括用户注册.忘记密码.登录(微信,微博等第三方登录:邮箱验证).登录后密码重置.邮箱发送密码重置链接.退出等. 安装与设置 运行CMD,打开虚拟环境 pip install django-allauth 安装好后设置Myblog / settings.py,将allauth相关APP加入到INST