vue 动态组件、异步组件

1、动态组件

    动态组件适用于在多标签页面中动态切换组件,通过component元素的is属性实现。

例如:需要在一个页面中动态切换商品介绍、商品评价和用户问答三个按钮标签,代码如下:

注册三个组件的实现代码:

在根实例中定义两个数据属性和一个计算属性,为了便于使用v-for指令循环渲染button按钮,以及动态切换组件,代码如下:

数据属性currentTab表示当前的标签页,tabs数组表示需要显示的数据属性内容,通过v-for标签来渲染tabs数组对应的标签,计算属性currentTabComponent代表当前选中的组件。接下来在与实例相关联的DOM模板中渲染按钮,以及动态切换软件,代码如下:

当点击一个按钮时,currentTab的值会更改,从而导致currentTabComponent的值更新,<component>元素的is属性使用v-bind指令绑定到一个已经注册组件的名字上,随着计算属性的改变,组件也就自动切换了。结果如下:

每次在切换新标签时,Vue都创建一个新的currentTabComponent实例,所有会导致之前修改标签里的内容不会被保存,为了避免重复渲染,可使用<keep-alive>标签包裹动态组件。

2、异步组件

    作用:将应用分割成较小的代码块,只在需要时才从服务器加载组件

   实现方式:以一个工厂函数的方式定义组件,然后异步解析组件定义

   结果:只有在组件被渲染时才触发工厂函数,并将结果缓存,用于下次渲染

   示例:

  

渲染结果:

推荐做法:异步组件+webpack的代码拆分功能

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值