vue3中setup函数的参数有什么,使用要注意哪些
导读:在实际案例的操作过程中,我们可能会遇到“vue3中setup函数的参数有什么,使用要注意哪些”这样的问题,那么我们该如何处理和解决这样的情况呢?这篇小编就给大家总结了一些方法,具有一定的借鉴价值,希望对大家有所帮助,接下来就让小编带领大家一...
在实际案例的操作过程中,我们可能会遇到“vue3中setup函数的参数有什么,使用要注意哪些”这样的问题,那么我们该如何处理和解决这样的情况呢?这篇小编就给大家总结了一些方法,具有一定的借鉴价值,希望对大家有所帮助,接下来就让小编带领大家一起了解看看吧。1.setUp函数的第1个参数props
setup(props,context){ }
第一个参数props:
props是一个对象,包含父组件传递给子组件的所有数据。
在子组件中使用props进行接收。
包含配置声明并传入的所有的属性的对象
也就是说:如果你想通过props的方式输出父组件传递给子组件的值。
你需要使用props进行接收配置。即props:{ ......}
如果你未通过Props进行接受配置,则输出的值是undefined【相关推荐:vue.js视频教程】
template> div> 父组件 /div> no-cont :mytitle="msg" othertitle="别人的标题" @sonclick="sonclick"> /no-cont> /template> script> import NoCont from "../components/NoCont.vue" export default { setup () { let msg={ title:'父组件给子给子组件的数据' } function sonclick(msss:string){ console.log(msss) } return { msg,sonclick} } , components:{ NoCont } } /script>
template> div @click="sonHander"> 我是子组件中的数据 /div> /template> script> import { defineComponent,setup } from 'vue'; export default defineComponent({ name: 'NoCont', // 未进行接受 // props:{ // mytitle:{ // type:Object // } // } , setup(props,context){ console.log('props==> ',props.mytitle); //输出的值是 undefined function sonHander(){ context.emit('sonclick','子组件传递给父组件') } return { sonHander} } } ); /script>
为什么通过props.mytitle输出的值是undefined呢?
因为我们没有使用props进行接收配置。即
props:{ mytitle:{ type:Object } } ,
如果我们添加上接受配置
2.参数context的讲解
第2个参数:context,是一个对象。
里面有attrs(获取当前标签上的所有属性的对象)
但是该属性是props中没有声明接收的所有的对象。
如果你使用props去获取值,同时props中你声明了你要获取的值
则:获取的值是undefined
注意点:
attrs获取值是不需要props中没有声明接收。
第1个参数props获取值是需要props中声明接收的
有emit事件分发,(传递给父组件需要使用该事件)
有slots插槽
template> div @click="sonHander"> 我是子组件中的数据 /div> /template> script> import { defineComponent,setup } from 'vue'; export default defineComponent({ name: 'NoCont', props:{ mytitle:{ type:Object } } , setup(props,context){ //输出{ title:父组件传递的值} console.log('props==> ',props.mytitle); // 输出别人的标题【使用context获取值,不需要使用props去接受】 console.log('context==> ',context.attrs.othertitle); // 输出undefined,因为context不需要使用props去接受。 console.log('contextmytitle==> ',context.attrs.mytitle); function sonHander(){ context.emit('sonclick','子组件传递给父组件') } return { sonHander} } } ); /script>
3. 子组件向父组件派发事件
template> div @click="sonHander"> 我是子组件中的数据 /div> /template> script> import { defineComponent,setup } from 'vue'; export default defineComponent({ name: 'NoCont', props:{ mytitle:{ type:Object } } , setup(props,context){ function sonHander(){ context.emit('sonclick','子组件传递给父组件') } return { sonHander} } } ); /script>
4.优化事件派发
我们知道第2个参数context是一个对象
并且对象中有三个属性attrs,slots,emit
在事件派发的时候,直接使用emit就ok了
template> div @click="sonHander"> 我是子组件中的数据 /div> /template> script> import { defineComponent,setup } from 'vue'; export default defineComponent({ name: 'NoCont', props:{ mytitle:{ type:Object } } , setup(props,{ attrs,slots,emit} ){ //直接使用emit进行事件派发 function sonHander(){ emit('sonclick','子组件传递给父组件') } return { sonHander} } } ); /script>
5.获取父组件传递的值
我们将使用props参数获取值
以及使用attrs获取值
template> hr/> h2> 子组件/h2> div @click="sonHander"> 我是子组件中的数据 /div> h2> 使用了props声明接收==> { { mytitle } } /h2> h2> 使用参数attrs获取==> { { attrs.othertitle } } /h2> /template> script> import { defineComponent,setup } from 'vue'; export default defineComponent({ name: 'NoCont', props:{ mytitle:{ type:Object } } , setup(props,{ attrs,slots,emit} ){ function sonHander(){ emit('sonclick','子组件传递给父组件') } return { sonHander,attrs} } } ); /script>
附使用setup函数时需要注意几点:
- setup函数的执行时机是在beforeCreate和created之间
- 由于setup执行时机是在created之间,所以组件才刚刚被创建,而data和methods还没初始化好,所以无法在setup中使用data和methods
- setup中this指向undefined
- setup只能是同步的,不能是异步的
以上就是关于vue3中setup函数的参数有什么,使用要注意哪些的介绍,本文内容仅供参考,有需要的朋友可以借鉴了解看看,希望对大家学习或工作,想要了解更多欢迎关注网络,小编每天都会为大家更新不同的知识。
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: vue3中setup函数的参数有什么,使用要注意哪些
本文地址: https://pptw.com/jishu/653561.html