一个用于装载进度条内容的 div (且叫做 container)。
然后在 container 里面动态生成三个元素,一个是做为背景的 div (且叫做 progress),一个是做为显示进度的 div (且叫做 bar),还有一个是显示文字的 span (且叫做 text)。
progress 的宽为 100%,bar 的宽根据传入数值 target 的值来定( 默认为 0 ,全部占满的值为 100 ),text 展示的文字为 bar 的宽占 progress 宽的百分比。
bar 的宽从 0 逐渐增加到的 target 值的过程( 比如: 0 > 80 ),给这个过程添加一个逐渐加快的动画。
具体的过程请看代码:
/*
* author: https://github.com/biaochenxuying
*/
(function() {
function Progress() {
this.mountedId = null;
this.target = 100;
this.step = 1;
this.color = '#333';
this.fontSize = '18px';
this.borderRadius = 0;
this.backgroundColor = '#eee';
this.barBackgroundColor = '#26a2ff';
}
Progress.prototype = {
init: function(config) {
if (!config.mountedId) {
alert('请输入挂载节点的 id');
return;
}
this.mountedId = config.mountedId;
this.target = config.target || this.target;
this.step = config.step || this.step;
this.fontSize = config.fontSize || this.fontSize;
this.color = config.color || this.color;
this.borderRadius = config.borderRadius || this.borderRadius;
this.backgroundColor = config.backgroundColor || this.backgroundColor;
this.barBackgroundColor =
config.barBackgroundColor || this.barBackgroundColor;
var box = document.querySelector(this.mountedId);
var width = box.offsetWidth;
var height = box.offsetHeight;
var progress = document.createElement('div');
progress.style.position = 'absolute';
progress.style.height = height + 'px';
progress.style.width = width + 'px';
progress.style.borderRadius = this.borderRadius;
progress.style.backgroundColor = this.backgroundColor;
var bar = document.createElement('div');
bar.style.float = 'left';
bar.style.height = '100%';
bar.style.width = '0';
bar.style.lineHeight = height + 'px';
bar.style.textAlign = 'center';
bar.style.borderRadius = this.borderRadius;
bar.style.backgroundColor = this.barBackgroundColor;
var text = document.createElement('span');
text.style.position = 'absolute';
text.style.top = '0';
text.style.left = '0';
text.style.height = height + 'px';
text.style.lineHeight = height + 'px';
text.style.fontSize = this.fontSize;
text.style.color = this.color;
progress.appendChild(bar);
progress.appendChild(text);
box.appendChild(progress);
this.run(progress, bar, text, this.target, this.step);
},
/**
* @name 执行动画
* @param progress 底部的 dom 对象
* @param bar 占比的 dom 对象
* @param text 文字的 dom 对象
* @param target 目标值( Number )
* @param step 动画步长( Number )
*/
run: function(progress, bar, text, target, step) {
var self = this;
++step;
var endRate = parseInt(target) - parseInt(bar.style.width);
if (endRate <= step) {
step = endRate;
}
var width = parseInt(bar.style.width);
var endWidth = width + step + '%';
bar.style.width = endWidth;
text.innerhtml = endWidth;
if (width >= 94) {
text.style.left = '94%';
} else {
text.style.left = width + 1 + '%';
}
if (width === target) {
clearTimeout(timeout);
return;
}
var timeout = setTimeout(function() {
self.run(progress, bar, text, target, step);
}, 30);
},
};
// 注册到 window 全局
window.Progress = Progress;
})();
var config = {
mountedId: '#bar',
target: 8,
step: 1,
color: 'green',
fontSize: "20px",
borderRadius: "5px",
backgroundColor: '#eee',
barBackgroundColor: 'red',
};
var p = new Progress();
p.init(config);
向web前端开发者整理提供的chrome插件或应用:比如Postman、JSON Viewer、Page Ruler 、ChromeADB 等等
作为前端开发,我们都习惯使用一些开源的插件例如jquery工具库,那么如何使用原生js来开发封装一个自己的插件呢?接下来就看一下怎么去开发一个自己的js插件,先上代码
jquery.typeahead.js是一款高级的自动补全jQuery插件。该自动补全插件提供超过50个配置选项和回调方法,用于完成自动补全功能,能够完成绝大部分表单自动补全的需求。
这篇文章为大家分享图片轮播插件,最全最简单最通用的 幻灯片轮播插件,pc端和移动端都可完美使用,能满足绝大部分网站的轮播需求。js轮播插件包括Swiper、slick、owl carousel2、jssor/slider 、iSlider 等
在上个项目中,客户希望时间选择插件可以是ios风格的那种,但是找了很久,发现并没有用vue的ios风格时间插件,于是自己便自己造了一个轮子.插件依赖于better-scroll和vue
在前端开发中,使用Visual Studio Code有哪些你常用的插件?推荐几个自己喜欢的,不带链接,自己搜索安装吧。这些都是比较实用、前端必备的插件集
常用谷谷歌浏览器确实没有其它国产软件的内置功能丰富。但是 Google 浏览器的的优点恰恰就体现在拥有超简约的界面,以及支持众多强大好用的扩展程序,用户能够按照自己的喜好去个性化定制浏览器。今天我就给大家介绍几款自己常用的插件。
安装Sublime text 2插件很方便,可以直接下载安装包解压缩到Packages目录,也可以安装package control组件,然后直接在线安装
BlockUI 插件是用于进行AJAX操作时模拟同步传输时锁定浏览器操作。当它被激活时,它会阻止使用者与页面(或页面的一部分)进行交互,直至它被取消。BlockUI以在DOM中添加元素的方法来实现阻止用户与浏览器交互的外观和行为
使用vscode开发vue项目的时候,从远端拉下一个新的项目后,安装完依赖后跑起项目时,发现直接报了一堆语法错误:包括换行、空格、单双引号、分号等各种格式问题
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!