用js写一个网页进度条

一、基本思路

为了让我们编写的网页进度条满足现有需求,又足够轻便,所以使用原生js写一个构造函数,为了见名知义,可以把该函数命名为”Loading”。该函数接收2个参数,分别为arr、callback。其中arr定义图片数组,callback定义执行完成后回调函数。该构造函数内部,遍历图片数组加载图片,每加载完一张图片,修改进度条进度,直至全部加载完成,进度条进度为100%。

二、实现步骤

(1)先搭建好进度条的样子,把html和css写好。

 

 

 

写完后预览一下进度条的效果

 

 

2)编写Loading构造函数。在该构造函数中,把进度条的css和html在执行进度条init方法时动态添加和渲染。至此,进度条模块已经编写好,使用时只需要引入该构造函数,并实例化一个对象。

 

 

3)实例化一个进度条对象

 

 

三、改进

该组件的可扩展性稍弱,主要表现为进度条样式上,可以根据不同进度条实例来定义进度条样式。所以可以在构造函数中增加一个this.setCss方法,实现不同进度条实例的个性化。修改如下:

 

 

如果进度条颜色为红色,不是默认的#01ffff,则在初始化前调用setCss方法。

 

 

页面效果如下

 

 

四、总结

该进度条插件已经开发完成,仍有很多可优化的点,比如加载进度条的动画可以更加优雅,配置样式时可以更简洁,代码的可读性等。优化无止境,同学仍需努力。

 

转载于:https://www.cnblogs.com/sherry-long/p/7636676.html

要在网页的顶部添加一个进度条,你可以使用 CSS 中的 `position fixed` 来固定进度条的,并使用 JavaScript 来监听页面滚动事件并进度条的宽度。 首先,在 HTML 文件中添加一个 `<div>` 元素作为进度条的容,并为其设置一个一的 ID: ```html<div id="progress-bar"></div``` 接下来 CSS 文件中为进度条容器设置样式,例如: ```css #progress-bar { position: fixed; top: 0; left: 0; width: 0; height: 3px; background-color: blue; z-index: 9999; transition: width 0.3s ease-out; /* 可选:添加过渡效果 */ } ``` 然后,使用 JavaScript 监听页面滚动事件,并更新进度条的宽度。可以在页面加载完成后执行以下代码: ```javascript window.addEventListener('scroll', function() { var scrollTop = document.documentElement.scrollTop || document.body.scrollTop; var windowHeight = document.documentElement.scrollHeight - document.documentElement.clientHeight; var progress = (scrollTop / windowHeight) * 100; document.getElementById('progress-bar').style.width = progress + '%'; }); ``` 上述代码中,我们通过监听 `scroll` 事件来获取页面滚动的信息。然后,计算出当前滚动位置相对于整个页面高度的百分比,并将这个百分比值作为进度条的宽度。 通过以上步骤,你可以在网页的顶部添加一个进度条。你可以根据需要自定义进度条的样式和其他细节。 希望这个解答能够帮助到你。如果还有其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值