简单的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 相关文章推荐
JS之Date对象和获取系统当前时间详解
Jan 13 Javascript
JS简单实现多级Select联动菜单效果代码
Sep 06 Javascript
使用CSS+JavaScript或纯js实现半透明遮罩效果的实例分享
May 09 Javascript
js跨域资源共享 基础篇
Jul 02 Javascript
js与jquery分别实现tab标签页功能的方法
Nov 18 Javascript
localStorage实现便签小程序
Nov 28 Javascript
微信小程序实现验证码获取倒计时效果
Feb 08 Javascript
node的process以及child_process模块学习笔记
Mar 06 Javascript
JavaScript防止全局变量污染的方法总结
Aug 02 Javascript
详解vue移动端项目的适配(以mint-ui为例)
Aug 17 Javascript
小程序实现五星点评效果
Nov 03 Javascript
vue实现可拖拽的dialog弹框
May 13 Vue.js
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
php下过滤HTML代码的函数
2007/12/10 PHP
Zend studio文件注释模板设置方法
2013/09/29 PHP
php断点续传之如何分割合并文件
2014/03/22 PHP
IE7中javascript操作CheckBox的checked=true不打勾的解决方法
2009/12/07 Javascript
IE下双击checkbox反应延迟问题的解决方法
2014/03/27 Javascript
学习JavaScript正则表达式
2015/11/13 Javascript
使用jQuery判断浏览器滚动条位置的方法
2016/05/30 Javascript
javascript对浅拷贝和深拷贝的详解
2016/10/14 Javascript
jQuery点击头像上传并预览图片
2017/02/23 Javascript
将jquery.qqFace.js表情转换成微信的字符码
2017/12/01 jQuery
Vue.js 中的 v-cloak 指令及使用详解
2018/11/19 Javascript
如何解决jQuery 和其他JS库的冲突
2020/06/22 jQuery
Python实现批量修改文件名实例
2015/07/08 Python
Python中实现变量赋值传递时的引用和拷贝方法
2018/04/29 Python
Python实现E-Mail收集插件实例教程
2019/02/06 Python
详解如何从TensorFlow的mnist数据集导出手写体数字图片
2019/08/05 Python
使用python os模块复制文件到指定文件夹的方法
2019/08/22 Python
解决Python中回文数和质数的问题
2019/11/24 Python
pycharm双击无响应(打不开问题解决办法)
2020/01/10 Python
PyCharm如何导入python项目的方法
2020/02/06 Python
用python发送微信消息
2020/12/21 Python
一款纯css3实现的颜色渐变按钮的代码教程
2014/11/12 HTML / CSS
利用canvas实现图片下载功能来实现浏览器兼容问题
2019/05/31 HTML / CSS
HTML5新特性之type=file文件上传功能
2018/02/02 HTML / CSS
葡萄牙鞋子品牌:Fair
2016/12/10 全球购物
中国跨境电商:Tomtop
2017/03/16 全球购物
Bose法国官网:购买耳机、扬声器、家庭影院、专业音响
2017/12/21 全球购物
Hanro官网:奢华男士和女士内衣、睡衣和家居服
2018/10/25 全球购物
如何写一份好的自荐信
2014/01/02 职场文书
大学生期末自我鉴定
2014/02/01 职场文书
2014教师个人自我评价范文
2014/09/13 职场文书
出租房屋协议书
2014/09/14 职场文书
纪念9.18事变演讲稿
2014/09/14 职场文书
副检察长四风问题对照检查材料思想汇报
2014/10/07 职场文书
Apache SeaTunnel实现 非CDC数据抽取
2022/05/20 Servers
Apache POI操作批量导入MySQL数据库
2022/06/21 Servers