vue3中defineComponent 的作用

  • vue3中defineComponent 的作用已关闭评论
  • 119 次浏览
  • A+
所属分类:Web前端
摘要

vue3中,新增了 defineComponent ,它并没有实现任何的逻辑,只是把接收的 Object 直接返回,它的存在是完全让传入的整个对象获得对应的类型,它的存在就是完全为了服务 TypeScript 而存在的。

vue3中,新增了 defineComponent ,它并没有实现任何的逻辑,只是把接收的 Object 直接返回,它的存在是完全让传入的整个对象获得对应的类型,它的存在就是完全为了服务 TypeScript 而存在的。

我都知道普通的组件就是一个普通的对象,既然是一个普通的对象,那自然就不会获得自动的提示,

import { defineComponent } from 'vue'  const component = {   name: 'Home',   props:{     data: String,   },   setup // 没有该有的提示,这非常的不友好 }  export default component

但是当我们加上 defineComponent() 之后,就完全不一样了,可以获得自动提示,vue2、vue3的自动提示都有

 
import { defineComponent } from 'vue'  const component = {   name: 'Home',   props:{     data: String,   },   setup(){     // setup 可接受两个参数,一个props,和 context   } }  export default component

 

接下来看看 setup 中的两个参数 props 与 context ,
props指组件传递来的参数,并且ts可以推论出props的类型.props也就是 vue2 中组件中的 props
context 有三个属性 attrs slots emit 分别对应vue2中的 vue3中defineComponent 的作用slots插槽、$emit发送事件

import { defineComponent } from 'vue'  const component = {   name: 'Home',   props:{     data: String,   },   setup(props, context){     // props.data     // context.attrs    context.slots    context.emit    } }  export default component

 

作者:嘉奇
链接:https://www.jianshu.com/p/50ab6ac2e3e7
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。