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 相关文章推荐
jQuery提交多个表单的小例子
Jun 30 Javascript
JavaScript中this的使用详解
Nov 08 Javascript
jquery显示隐藏input对象
Jul 21 Javascript
JavaScript实现继承的4种方法总结
Oct 16 Javascript
js+css简单实现网页换肤效果
Dec 29 Javascript
jQuery简单注册和禁用全局事件的方法
Jul 25 Javascript
一个仿微博登陆邮箱提示框js开发案例
Jul 28 Javascript
纯js和css完成贪吃蛇小游戏demo
Sep 01 Javascript
js实现时间轴自动排列效果
Mar 09 Javascript
AntV F2和vue-cli构建移动端可视化视图过程详解
Oct 08 Javascript
JS函数参数的传递与同名参数实例分析
Mar 16 Javascript
详解JS WebSocket断开原因和心跳机制
May 07 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和HTML5 FormData实现无刷新文件上传教程
2014/09/06 PHP
PHP rsa加密解密使用方法
2015/04/27 PHP
php使用curl实现ftp文件下载功能
2017/05/16 PHP
thinkPHP5.0框架验证码调用及点击图片刷新简单实现方法
2018/09/07 PHP
JavaScript面向对象编程
2008/03/02 Javascript
javascript循环变量注册dom事件 之强大的闭包
2010/09/08 Javascript
40个有创意的jQuery图片、内容滑动及弹出插件收藏集之一
2011/12/31 Javascript
js实现弹窗插件功能实例代码分享
2013/12/12 Javascript
Jquery 改变radio/checkbox选中状态,获取选中的值(示例代码)
2013/12/12 Javascript
jquery 取子节点及当前节点属性值
2014/07/25 Javascript
JavaScript中的类与实例实现方法
2015/01/23 Javascript
javascript格式化json显示实例分析
2015/04/21 Javascript
学习Bootstrap组件之下拉菜单
2015/07/28 Javascript
JQuery datepicker 用法详解
2015/12/25 Javascript
微信小程序 支付功能实现PHP实例详解
2017/05/12 Javascript
vue单个组件实现无限层级多选菜单功能
2018/04/10 Javascript
使用vue-router完成简单导航功能【推荐】
2018/06/28 Javascript
解决Js先触发失去焦点事件再执行点击事件的问题
2018/08/30 Javascript
基于Vue sessionStorage实现保留搜索框搜索内容
2020/06/01 Javascript
[02:31]DOTA2帕克 英雄基础教程
2013/11/26 DOTA
python pickle 和 shelve模块的用法
2013/09/16 Python
Python元组操作实例分析【创建、赋值、更新、删除等】
2017/07/24 Python
使用python进行文本预处理和提取特征的实例
2018/06/05 Python
python 去除二维数组/二维列表中的重复行方法
2019/01/23 Python
django在保存图像的同时压缩图像示例代码详解
2020/02/11 Python
基于Keras 循环训练模型跑数据时内存泄漏的解决方式
2020/06/11 Python
python/golang 删除链表中的元素
2020/09/14 Python
哈利波特商店:Harry Potter Shop
2018/11/30 全球购物
女士和男士时尚鞋在线购物:Shoespie
2019/02/28 全球购物
旅游管理专业个人求职信范文
2013/12/24 职场文书
工程专业应届生求职信
2014/02/19 职场文书
信息管理应届生求职信
2014/03/07 职场文书
计算机系本科生求职信
2014/05/31 职场文书
品质标语大全
2014/06/21 职场文书
解决MySQL存储时间出现不一致的问题
2021/04/28 MySQL
SQLServer常见数学函数梳理总结
2022/08/05 MySQL