刚学习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"> <link rel="stylesheet" href="https://cdn.bootcss.com/foundation/5.5.3/css/foundation.min.css" rel="external nofollow" rel="external nofollow" > <link rel="stylesheet" href="http://static.runoob.com/assets/foundation-icons/foundation-icons.css" rel="external nofollow" rel="external nofollow" > <title>jq进度条</title> </head> <body> <div id="app"> <div class="progress round alert"> <span class="meter" style="width:0%">0%</span> </div> </div> <script src="https://cdn.bootcss.com/vue/2.4.4/vue.min.js"></script> <script src="https://cdn.bootcss.com/jquery/2.1.1/jquery.min.js "></script> <script src="https://cdn.bootcss.com/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); 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="https://cdn.bootcss.com/foundation/5.5.3/css/foundation.min.css" rel="external nofollow" rel="external nofollow" > <link rel="stylesheet" href="http://static.runoob.com/assets/foundation-icons/foundation-icons.css" rel="external nofollow" rel="external nofollow" > <style> .bar{ color: #fff; text-align: center; } </style> </head> <body> <div id="app"> <div class="progress alert round"> <span class="meter bar" :style="{width:proBar+'%',}" >{{proBar}}</span> </div> </div> <script src="https://cdn.bootcss.com/vue/2.4.4/vue.min.js"></script> <script src="https://cdn.bootcss.com/jquery/2.1.1/jquery.min.js "></script> <script src="https://cdn.bootcss.com/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时期已经全部完成初始化,所以便不会成功。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍jQuery简单实现提交数据出现loading进度条的方法,包括了jQuery简单实现提交数据出现loading进度条的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jQuery简单实现提交数据出现loading进度条的方法。分享给大家供大家参考,具体如下: html部分代码如下,复制然后引入类库即可使用 jQuery部分代码如下: php代码: 更多关于jQuery相
本文向大家介绍javascript实现简单的进度条,包括了javascript实现简单的进度条的使用技巧和注意事项,需要的朋友参考一下 示例一: 再来分享一个结合.net的 建立一个WEB工程,添加新项->HTML页面,命名为ProgressBar.htm,内容如下: 后台代码,Default.aspx.cs:
本文向大家介绍简单实现python进度条脚本,包括了简单实现python进度条脚本的使用技巧和注意事项,需要的朋友参考一下 最近需要用Python写一个小脚本,用到了一些小知识,赶紧抽空记录一下。不深但是常用。 两个进度条示例,拷贝就能运行: 提供一个自己写的一个简单异步进度条,可以在耗时操作前开启,然后再耗时操作结束后停止。 用法: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多
本文向大家介绍php实现简单的上传进度条,包括了php实现简单的上传进度条的使用技巧和注意事项,需要的朋友参考一下 Web上传文件的三种解决方案分享给大家: 这里我要使用的是form法。通过为表单元素设置enctype=”multipart/form-data”属性,让表单提交的数据以二进制编码的方式提交,在接收此请求的Servlet中用二进制流来获取内容,就可以取得上传文件的内容,从而实现文件的
本文向大家介绍vue实现拖拽进度条,包括了vue实现拖拽进度条的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了vue实现拖拽进度条的具体代码,供大家参考,具体内容如下 组件代码: 调用: 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。
本文向大家介绍PHP实现简单ajax Loading加载功能示例,包括了PHP实现简单ajax Loading加载功能示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHP实现简单ajax Loading加载功能。分享给大家供大家参考,具体如下: 测试的时候,被 Chrome 给绊着了。请看下边解释: 这样写本来就不会接到.readyState==1的回应 因为1是表示已经调用.ope