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 相关文章推荐
ext combox 下拉框不出现自动提示,自动选中的解决方法
Feb 24 Javascript
改变隐藏的input中value的值代码
Dec 30 Javascript
jquery的clone方法应用于textarea和select的bug修复
Jun 26 Javascript
jQuery实现无限往下滚动效果代码
Apr 16 Javascript
在javaScript中检测数据类型的几种方式小结
Mar 04 Javascript
Vue.extend构造器的详解
Jul 17 Javascript
vue.js的手脚架vue-cli项目搭建的步骤
Aug 30 Javascript
thinkjs 文件上传功能实例代码
Nov 08 Javascript
Vue内部渲染视图的方法
Sep 02 Javascript
JavaScript实现简单随机点名器
Nov 21 Javascript
ES6 async、await的基本使用方法示例
Jun 06 Javascript
SpringBoot+Vue开发之Login校验规则、实现登录和重置事件
Oct 19 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
2006/12/14 PHP
php disk_free_space 返回目录可用空间
2010/05/10 PHP
比file_get_contents稳定的curl_get_contents分享
2012/01/11 PHP
PHP7之Mongodb API使用详解
2015/12/26 PHP
yii2-GridView在开发中常用的功能及技巧总结
2017/01/07 PHP
phpstorm激活码2020附使用详细教程
2020/09/25 PHP
简单JS代码压缩器
2006/10/12 Javascript
jquery tablesorter.js 支持中文表格排序改进
2009/12/09 Javascript
深入理解JavaScript系列(40):设计模式之组合模式详解
2015/03/04 Javascript
JS对字符串编码的几种方式使用指南
2015/05/14 Javascript
原生JS实现的放大镜效果实例代码
2016/10/15 Javascript
Agularjs妙用双向数据绑定实现手风琴效果
2017/05/26 Javascript
vue中的非父子间的通讯问题简单的实例代码
2017/07/19 Javascript
jQuery访问浏览器本地存储cookie、localStorage和sessionStorage的基本用法
2017/10/20 jQuery
js隐式转换的知识实例讲解
2018/09/28 Javascript
JS使用栈判断给定字符串是否是回文算法示例
2019/03/04 Javascript
element-ui 本地化使用教程详解
2019/10/28 Javascript
VUE动态生成word的实现
2020/07/26 Javascript
python多线程http下载实现示例
2013/12/30 Python
Python使用PyGreSQL操作PostgreSQL数据库教程
2014/07/30 Python
Sanic框架路由用法实例分析
2018/07/16 Python
python使用Matplotlib画条形图
2020/03/25 Python
对python插入数据库和生成插入sql的示例讲解
2018/11/14 Python
python使用Word2Vec进行情感分析解析
2020/07/31 Python
英国剑桥包中文官网:The Cambridge Satchel Company中国
2018/11/06 全球购物
27个经典Linux面试题及答案,你知道几个?
2014/03/11 面试题
岗位竞聘书范文
2014/03/31 职场文书
小区文明倡议书
2014/05/16 职场文书
实习协议书范本
2014/09/25 职场文书
家庭财产分割协议书范本
2014/11/24 职场文书
泰坦尼克号观后感
2015/06/04 职场文书
文艺部部长竞选稿
2015/11/21 职场文书
2016春季幼儿园大班开学寄语
2015/12/03 职场文书
Python数据分析入门之教你怎么搭建环境
2021/05/13 Python
用python实现监控视频人数统计
2021/05/21 Python
PyQt5结合QtDesigner实现文本框读写操作
2021/06/11 Python