vue 函数化组件

Vue.js提供了一个functional的布尔值选项,设置为true可以使组件无状态和无实例,也就是没有datathis上下文。这样用render函数返回虚拟节点可以更容易渲染,因为函数化组件只是一个函数,渲染开销要小很多。

使用函数化组件时,Render函数提供了第二个参数context来提供临时上下文。组件需要的data、props、slots、children、parent都是通过这个上下文来传递的,比如this.level要改写为context.props.level, this.$slots.default改写为context.children

例如,下面的示例用函数化组件展示了一个根据数据智能选择不同组件的场景:

        

代码片段比较长,逐步分析一下实现的内容。ImgItem、VideoItem、TextItem这3个对象分别是图片组件、视频组件和纯文本组件的选项,它们都接收一个prop:data。在函数化组件smart-item里,也有props:data,通过getComponent函数来判断其字段type的值,选择这条数据适合渲染的组件。通过createElementgetComponent()返回的对象设置为第一个参数,然后通过第二个参数把smart-itemdata传递到选择的组件里的prop:data,组件渲染出不同的内容。

根实例app中的方法change用来生成不同的数据,通过3个button来切换。

该示例难理解的地方在于smart-item和3个功能组件都有prop:data,它们的传递顺序和原理看起来比较含糊。

函数化组件在业务中并不是很常用,而且也有其他类似的方法来实现,比如上例也可以用组件的is特性来动态挂载。总结起来,函数化组件主要适用于以下两个场景:

● 程序化地在多个组件中选择一个。

● 在将children, props,data传递给子组件之前操作它们。

你可能感兴趣的:(vue 函数化组件)