分享更有价值
被信任是一种快乐

vue使用异步组件的原因有哪些

文章页正文上

本篇内容主要讲解“vue使用异步组件的原因有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue使用异步组件的原因有哪些”吧! 使用异步组件的原因:1、异步组件可以减少打包的结果,会将异步组件分开打包,会采用异步的方式加载组件,可以有效的解决一个组件过大的问题。2、异步组件的核心可以给组件定义变成一个函数,函数里面可以用import语法,实现文件的分割加载。1.异步组件可以减少打包的结果。会将异步组件分开打包,会采用异步的方式加载组件,可以有效的解决一个组件过大的问题。不使用异步组件,如果组件功能比较多打包出来的结果就会变大。2.异步组件的核心可以给组件定义变成一个函数,函数里面可以用import语法,实现文件的分割加载,import语法是webpack提供的,采用的就是jsonp。

components:{
VideoPlay:(resolve)=>import("../components/VideoPlay")
}

components:{
VideoPlay(resolve){
require(["../components/VideoPlay"],resolve)
}
}

或者使用回调函数

在createComponent方法中,会有相应的异步组件处理,首先定义一个asyncFactory变量,然后进行判断,如果组件是一个函数,然后会去调resolveAsyncComponent方法,然后将赋值在asyncFactory上的函数传进去,会让asyncFactory马上执行,执行的时候并不会马上返回结果,因为他是异步的,返回的是一个promise,这时候这个值就是undefined,然后就会先渲染一个异步组件的占位,空虚拟节点。如果加载完之后会调factory函数传入resolve和reject两个参数,执行后返回一个成功的回调和失败的回调,promise成功了就会调resolve,resolve中就会调取forceRender方法强制更新视图重新渲染,forceRender中调取的就是$forceUpdate,同时把结果放到factory.resolved上,如果强制刷新的时候就会再次走resolveAsyncComponent方法,这时候有个判断,如果有成功的结果就把结果直接放回去,这时候resolveAsyncComponent返回的就不是undefined了,就会接的创建组件,初始化组件,渲染组件。src/core/vdom/create-component.js1.createComponent方法

exportfunctioncreateComponent(
Ctor:Class|Function|Object|void,
data:?VNodeData,
context:Component,
children:?Array,
tag?:string
):VNode|Array|void{
letasyncFactory
if(isUndef(Ctor.cid)){//看组件是否是一个函数
asyncFactory=Ctor//异步组件一定是一个函数新版本提供了对象的写法
Ctor=resolveAsyncComponent(asyncFactory,baseCtor)//默认调用此函数时返回undefiend
//第二次渲染时Ctor不为undefined
if(Ctor===undefined){
//返回async组件的占位符节点
//作为注释节点,但保留该节点的所有原始信息
//该信息将用于异步服务器渲染和水合。
returncreateAsyncPlaceholder(
asyncFactory,
data,
context,
children,
tag
)
}
}
}

2.resolveAsyncComponent方法

exportfunctionresolveAsyncComponent(
factory:Function,
baseCtor:Class
):Class|void{
//如果有错误就返回错误结果
if(isTrue(factory.error)&&isDef(factory.errorComp)){
returnfactory.errorComp
}
//再次渲染时可以拿到获取的最新组件
//如果有成功的结果,就直接返回去
if(isDef(factory.resolved)){
returnfactory.resolved
}

if(owner&&!isDef(factory.owners)){
//forceRender强制刷新渲染
constforceRender=(renderCompleted:boolean)=>{
for(leti=0,l=owners.length;i)=>{
factory.resolved=ensureCtor(res,baseCtor)
if(!sync){
forceRender(true)//执行强制更新视图重新渲染方法
}else{
owners.length=0
}
})
//失败
constreject=once(reason=>{
if(isDef(factory.errorComp)){
factory.error=true
forceRender(true)
}
})

//执行factory将resolve方法和reject方法传入
constres=factory(resolve,reject)

sync=false
returnfactory.loading?factory.loadingComp:factory.resolved//返回结果
}
}

3.createAsyncPlaceholder 方法

//创建一个异步组件的占位,空虚拟节点也就是一个注释
exportfunctioncreateAsyncPlaceholder(
factory:Function,
data:?VNodeData,
context:Component,
children:?Array,
tag:?string
):VNode{
constnode=createEmptyVNode()
node.asyncFactory=factory
node.asyncMeta={data,context,children,tag}
returnnode
}

到此,相信大家对“vue使用异步组件的原因有哪些”有了更深的了解,不妨来实际操作一番吧!这里是云技术网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

推荐阅读:
  1. vue怎么通过点击事件弹出弹窗页面
  2. 提高开发效率和性能的Vue技巧有哪些

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@byun.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue

  • 上一篇新闻:

    vue中mixin和组件的区别有哪些
  • 下一篇新闻:

    vue页面渲染是异步的吗

猜你喜欢

  • php通过mysql导入的数据操作solr7.5详细步骤
  • phpstorm使用ftp工具
  • phpstorm基本配置
  • phpredis — Redis编译安装,PHP 7 安装 Redis 扩展
  • php的基础知识
  • zabbix 监控phpfpm_status
  • 分享PHP中的10个实用函数
  • redis的php驱动两种方式
  • php json_encode 将数组转换成json格式数据出错
  • php使用zeromq

最新资讯
  • python高阶函数functools模块如何使用
  • 怎么使用vue-pdf插件实现pdf文档预览功能
  • AndroidFlutter怎么在点击事件上添加动画效果
  • Springboot整合多数据源配置流程是什么
  • Python中JsonPath提取器和正则提取器怎么使用
  • SpringBootJPA常用注解如何使用
  • 怎么使用JS实现一个跟随鼠标移动洒落的星星特效
  • 怎么使用vue+echarts绘制折线图、柱状图和扇形图
  • Redis与MySQL的双写一致性问题怎么解决
  • Python中的描述器怎么使用
相关推荐
  • vue如何自定义加载指令
  • 如何利用vue3.x绘制流程图
  • Vue路由组件如何通过props配置传参
  • 怎么使用Vue+Canvas制作简易的水印添加器小工具
  • Vue前端项目自适应布局怎么实现
  • vue+js怎么实现轮播,滚动公告,衔接效果
  • Vue常用内置指令有哪些
  • Vue项目中怎么解决跨域问题
  • Vue组件怎么设置Props
  • 免费云主机、域名

  • vue有没有内置jquery

相关标签

vue.js
vue-router
vue-cli3
ant-design-vue
vue路由
vue.component
vue2.0
vue router
vue项目
vue-cli3.0
vue-video-player
vuecli3
vue-cli3.x
vue.use()
vue-i18n
vue打包
vue-cli2.x
vue1
vue-loader
vue-awesome-swiper

云服务器、web空间可免费试用

宝塔面板主机、支持php,mysql等,SSL部署;安全高速企业专供99.999%稳定,另有高防主机、不限制内容等类型,具体可咨询QQ:360163164,Tel同微信:18905205712

主机选购导航云服务器试用

登录

找回密码

注册