vue实现简单loading进度条


Posted in Javascript onJune 06, 2018

刚学习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时期已经全部完成初始化,所以便不会成功。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Apply an AutoFormat to an Excel Spreadsheet
Jun 12 Javascript
实例分析js和C#中使用正则表达式匹配a标签
Nov 26 Javascript
分享33个jQuery与CSS3实现的绚丽鼠标悬停效果
Dec 15 Javascript
jQuery源码解读之hasClass()方法分析
Feb 20 Javascript
jQuery仿360导航页图标拖动排序效果代码分享
Aug 24 Javascript
html5+javascript实现简单上传的注意细节
Apr 18 Javascript
JS中setTimeout和setInterval的最大延时值详解
Feb 13 Javascript
js实现可以点击收缩或张开的悬浮窗
Sep 18 Javascript
vue如何引入sass全局变量
Jun 28 Javascript
vue awesome swiper异步加载数据出现的bug问题
Jul 03 Javascript
vue自定义底部导航栏Tabbar的实现代码
Sep 03 Javascript
8 个有用的JS技巧(推荐)
Jul 03 Javascript
security.js实现的RSA加密功能示例
Jun 06 #Javascript
Vue ElementUi同时校验多个表单(巧用new promise)
Jun 06 #Javascript
基于vue实现可搜索下拉框定制组件
Mar 26 #Javascript
深入浅析Vue中的 computed 和 watch
Jun 06 #Javascript
详解创建自定义的Angular Schematics
Jun 06 #Javascript
vue组件实现进度条效果
Jun 06 #Javascript
Express的HTTP重定向到HTTPS的方法
Jun 06 #Javascript
You might like
用PHP开发GUI
2006/10/09 PHP
php SQL Injection with MySQL
2011/02/27 PHP
apache配置虚拟主机的方法详解
2013/06/17 PHP
php解析字符串里所有URL地址的方法
2015/04/03 PHP
PHP自定义多进制的方法
2016/11/03 PHP
jQuery使用手册之二 DOM操作
2007/03/24 Javascript
JavaScript 不只是脚本
2007/05/30 Javascript
jquery.validate分组验证代码
2011/03/17 Javascript
jQuery 获取/设置/删除DOM元素的属性以a元素为例
2014/05/23 Javascript
jQuery表格列宽可拖拽改变且兼容firfox
2014/09/03 Javascript
在JavaScript中处理字符串之link()方法的使用
2015/06/08 Javascript
js实现文件上传表单域美化特效
2015/11/02 Javascript
JS中innerHTML和pasteHTML的区别实例分析
2016/06/22 Javascript
js实现图片缓慢放大缩小效果
2016/08/02 Javascript
基于Angularjs+mybatis实现二级评论系统(仿简书)
2017/02/13 Javascript
Nodejs中使用captchapng模块生成图片验证码
2017/05/18 NodeJs
利用jQuery+localStorage实现一个简易的计时器示例代码
2017/12/25 jQuery
使用Vue开发动态刷新Echarts组件的教程详解
2018/03/22 Javascript
Puppet的一些技巧
2018/09/17 Javascript
NodeJS 将文件夹按照存放路径变成一个对应的JSON的方法
2018/10/17 NodeJs
如何将百度地图包装成Vue的组件的方法步骤
2019/02/12 Javascript
Vue 开发必须知道的36个技巧(小结)
2019/10/09 Javascript
python中的列表推导浅析
2014/04/26 Python
pycharm远程调试openstack代码
2017/11/21 Python
Python读取properties配置文件操作示例
2018/03/29 Python
用python编写第一个IDA插件的实例
2018/05/29 Python
python打开windows应用程序的实例
2019/06/28 Python
pytorch方法测试——激活函数(ReLU)详解
2020/01/15 Python
pytorch中的inference使用实例
2020/02/20 Python
css3 给页面加个半圆形导航条主要利用旋转和倾斜样式
2014/02/10 HTML / CSS
英国皇家邮政海外旗舰店:Royal Mail
2018/02/21 全球购物
招聘与培训专员岗位职责
2014/01/30 职场文书
《浅水洼里的小鱼》听课反思
2014/02/28 职场文书
新年主持词
2014/03/27 职场文书
婚庆主持词大全
2015/06/30 职场文书
Python Pandas 删除列操作
2022/03/16 Python