vue实现简单loading进度条
刚学习vue不久,今天试着⽤vue做了⼀个简单的loading进度条,对于vue的⽣命周期和钩⼦函数⼜有了新的理解,下⾯分享给⼤家,绝对⼊门级。
⼀、进度条原理
这个就很简单了,也是我们经常可以⽤到的,这⾥只做⼀个最简单的,页⾯刷新⾃动加载进度条。主要是让进度条的width不断增加⾄100%就可以啦~好了,进⼊正题。
⼆、jquery实现
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
jquery下载文件进度条<link rel="stylesheet" href="cdn.bootcss/foundation/5.5.3/css/foundation.min.css" >
<link rel="stylesheet" href="static.runoob/assets/foundation-icons/foundation-icons.css" >
<title>jq进度条</title>
</head>
<body>
<div id="app">
<div class="progress round alert">
<span class="meter" >0%</span>美国总统大选投票
</div>
</div>
<script src="cdn.bootcss/vue/2.4.4/vue.min.js"></script>
<script src="cdn.bootcss/jquery/2.1.1/jquery.min.js "></script>
<script src="cdn.bootcss/foundation/5.5.3/js/foundation.min.js "></script>
<script>
$(function () {
var html = $('.meter');
var htmlW = $('.meter').val();
var styleW = parseInt($('.meter').css('width'));
var clearInt = setInterval(function () {
styleW++;
var styleWW = styleW + '%';
html.css('width', styleWW);
ping批处理文件怎么写
html.html(styleWW);
if (styleW == 100) {
clearInterval(clearInt);
}
}, 20)
})
</script>
</body>
</html>
三、vue实现
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>vue进度条</title>
<link rel="stylesheet" href="cdn.bootcss/foundation/5.5.3/css/foundation.min.css" >
<link rel="stylesheet" href="static.runoob/assets/foundation-icons/foundation-icons.css" >
<style>
.bar{
color: #fff;
text-align: center;c 语言修仙
}
</style>
</head>
<body>
mysql中sql优化<div id="app">
<div class="progress alert round">
<span class="meter bar" : >{{proBar}}</span>嵌入式开发培训大纲
</div>
</div>
<script src="cdn.bootcss/vue/2.4.4/vue.min.js"></script>
<script src="cdn.bootcss/jquery/2.1.1/jquery.min.js "></script>
<script src="cdn.bootcss/foundation/5.5.3/js/foundation.min.js "></script>
<script>
var app = new Vue({
el: '#app',
data: {
proBar: 0,
},
created(){
this.change();
},
methods: {
change: function() {
var clearInt = setInterval(function() {
app.proBar++;
console.log(app.prpBar);
if (app.proBar == 100) {
clearInterval(clearInt);
}
}, 20)
}
}
})
</script>
</body>
</html>
对⽐两段代码显然vue要⽅便许多,因为是双向绑定,不⽤来回操作dom,就很简单省⼼啦。
注意问题:刚开始没有实现loading效果,主要是因为⽤了mounted钩⼦函数来调⽤change⽅法(还是对⽣命周期理解的不到位)。实现loading效果我们需要在页⾯加载时⾃动调⽤change⽅法,所以我们应该在数据全部初始化前就执⾏这⼀操作。mounted时期已经全部完成初始化,所以便不会成功。
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论