简单的Vue异步组件实例Demo


Posted in Javascript onDecember 27, 2017

前言

在大型应用中,我们可能需要将应用拆分为多个小模块,按需从服务器下载。为了进一步简化,Vue.js 允许将组件定义为一个工厂函数,异步地解析组件的定义。Vue.js 只在组件需要渲染时触发工厂函数,并且把结果缓存起来,用于后面的再次渲染。

为什么需要异步组件,道理和webpack的按需加载是一样的,如果一开始就加载所有的组件,那么是比较耗时的,所以我们可以将一些组件定义为异步组件,在需要使用的时候再进行加载。

所以好处的话就显而易见了 :

  • 按需加载,可以节省首次加载的时间,提高速度,也算是一个性能优化。
  • 那么一个组件可能会被使用多次,按需加载的话也不会加载多次,第一次加载完成就会缓存下来,和webpack是一样的,所以不用担心

最近读Vue文档的时候仔细看了一下异步组件部分,第一次看的时候一脸懵逼,看第二次还是有点迷茫,第三次就有点感觉了,第四次感觉有点明白了,遂记录一下,下面是我写的一个简单Vue异步组件Demo。

实例代码

index.html

<!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>Document</title>
  <script>
   // 如果浏览器不支持Promise就加载promise-polyfill
   if ( typeof Promise === 'undefined' ) {
    var script = document.createElement( 'script' );
    script.type = 'text/javascript';
    script.src = 'https://cdn.jsdelivr.net/npm/es6-promise@4/dist/es6-promise.auto.min.js';
    document.head.appendChild( script );
   }
  </script>
  <!-- 引入Vue -->
  <script src="https://cdn.jsdelivr.net/npm/vue"></script>
 </head>
 <body>
  <div id="app" style="font-size: 22px">
   <!-- 异步组件async-comp -->
   <async-comp :list="['我是一个异步组件,','如果加载完成,','我就会在这里显示']"></async-comp>
  </div>

  <!-- 引入main.js  -->
  <script src="/main.js"></script>
 </body>
</html>

异步组件Async-Comp.js,

注意,Async-Comp.js并没有在index.html中引用,而是在下面的main.js中动态加载。

window.async_comp = {
 template: '\
  <ol>\
   <li v-for="item in list">{{ item }}</li>\
  </ol>',
 props: {
  list: Array
 }
};

main.js

var vm = new Vue( {
 el: '#app',
 components: {
  /* 异步组件async-comp */
  'async-comp': function () {
   return {
    /** 要渲染的异步组件,必须是一个Promise对象 */
    component: new Promise( function ( resolve, reject ) {
     var script = document.createElement( 'script' );
     script.type = 'text/javascript';
     script.src = '/Async-Comp.js';
     document.head.appendChild( script );
     script.onerror = function () {
      reject( 'load failed!' );
     }

     script.onload = function () {
      if ( typeof async_comp !== 'undefined' )
       resolve( async_comp );
      else reject( 'load failed!' )
     }
    } ),
    /* 加载过程中显示的组件 */
    loading: {
     template: '<p>loading...</p>'
    },
    /* 出现错误时显示的组件 */
    error: {
     template: '\
      <p style="color:red;">load failed!</p>\
     '
    },
    /* loading组件的延迟时间 */
    delay: 10,
    /* 最长等待时间,如果超过此时间,将显示error组件。 */
    timeout:3200
   }
  }
 }
} )

github地址:点击这里

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
兼容IE和FF的js脚本代码小结(比较常用)
Dec 06 Javascript
关于Javascript模块化和命名空间管理的问题说明
Dec 06 Javascript
JQuery表格内容过滤的实现方法
Jul 05 Javascript
jquery 显示*天*时*分*秒实现时间计时器
May 07 Javascript
JavaScript错误处理
Feb 03 Javascript
javascript判断数组内是否重复的方法
Apr 21 Javascript
javascript 四十条常用技巧大全
Sep 09 Javascript
利用jquery实现验证输入的是否是数字、小数,包含保留几位小数
Dec 07 Javascript
移动端web滚动分页的实现方法
May 05 Javascript
Vue-cli 使用json server在本地模拟请求数据的示例代码
Nov 02 Javascript
javascript获取元素的计算样式
May 24 Javascript
浅谈ECMAScript 中的Array类型
Jun 10 Javascript
Vue.js组件间的循环引用方法示例
Dec 27 #Javascript
全面介绍vue 全家桶和项目实例
Dec 27 #Javascript
CSS3结合jQuery实现动画效果及回调函数的实例
Dec 27 #jQuery
使用jQuery 操作table 完成单元格合并的实例
Dec 27 #jQuery
浅谈vue-router 路由传参的方法
Dec 27 #Javascript
关于laydate.js加载laydate.css路径错误问题解决
Dec 27 #Javascript
javascript连接mysql与php通过odbc连接任意数据库的实例
Dec 27 #Javascript
You might like
深入理解require与require_once与include以及include_once的区别
2013/06/05 PHP
PHP间隔一段时间执行代码的方法
2014/12/02 PHP
php构造方法中析构方法在继承中的表现
2016/04/12 PHP
PHP实现将MySQL重复ID二维数组重组为三维数组的方法
2016/08/01 PHP
PHP通过文件路径获取文件名的实例代码
2018/10/14 PHP
php 的多进程操作实践案例分析
2020/02/28 PHP
jQuery 快速结束当前正在执行的动画
2013/11/20 Javascript
jQuery可见性过滤器:hidden和:visibility用法实例
2015/06/24 Javascript
jQuery form 表单验证插件(fieldValue)校验表单
2016/01/24 Javascript
AngularJs 指令详解及示例代码
2016/09/01 Javascript
NodeJs下的测试框架Mocha的简单介绍
2017/02/22 NodeJs
js实现楼层导航功能
2017/02/23 Javascript
js实现添加删除表格(两种方法)
2017/04/27 Javascript
Angular 2父子组件数据传递之@Input和@Output详解 (上)
2017/07/05 Javascript
js字符限制(字符截取) 一个中文汉字算两个字符
2017/09/12 Javascript
基于Require.js使用方法(总结)
2017/10/26 Javascript
[01:05:36]VP vs TNC Supermajor小组赛B组 BO3 第二场 6.2
2018/06/03 DOTA
Python列表append和+的区别浅析
2015/02/02 Python
Python实现将n个点均匀地分布在球面上的方法
2015/03/12 Python
详解Python中映射类型的内建函数和工厂函数
2015/08/19 Python
Python3中条件控制、循环与函数的简易教程
2017/11/21 Python
Python实现的多线程同步与互斥锁功能示例
2017/11/30 Python
Django跨域请求CSRF的方法示例
2018/11/11 Python
详解Python3之数据指纹MD5校验与对比
2019/06/11 Python
Django 用户认证Auth组件的使用
2020/11/30 Python
Merchant 1948澳大利亚:新西兰领先的鞋类和靴子供应商
2018/03/24 全球购物
高校自主招生自荐信
2013/12/09 职场文书
学校办公室主任职责
2013/12/27 职场文书
迟到检讨书大全
2014/01/25 职场文书
总经理助理岗位职责范本
2014/07/20 职场文书
处级领导干部四风问题自我剖析材料
2014/09/29 职场文书
优秀党员先进材料
2014/12/18 职场文书
2016元旦文艺汇演主持词
2015/07/06 职场文书
五星级酒店宣传口号
2015/12/25 职场文书
matplotlib之pyplot模块实现添加子图subplot的使用
2021/04/25 Python
mysql备份策略的实现(全量备份+增量备份)
2021/07/07 MySQL