vue3中defineComponent 的作用

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中的 图片[1] - vue3中defineComponent 的作用 - MaxSSLslots插槽、$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
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享