首页 > web前端 > Vue.js > 正文

Vue3中props和emit怎么使用

WBOY
发布: 2023-05-26 18:13:15
转载
1857 人浏览过

作用:父组件通过 props 向下传递数据给子组件;

用途:当有一种类型的组件需要被使用多次,每一次的调用都只是特定的地方不同,就好像一张个人简介表,每次填的人的信息都不同,但是结构都是一样的。

用法1(不指定类型的简单接受):

在父组件里面引入子组件,通过子组件的标签属性传递参数,在子组件里面定义一个props选项进行接收使用,要注意在子组件里面不需要在props以外的地方事先定义

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

在上面可以看见传进来的age是一个字符串类型,如果想要让传进来的值自动加1不能在子组件使用时里面+1,如下图所示会变成字符串加法241

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

 正确的解决方案是在父组件进行传参时就要进行使用v-bind进行动态绑定,又或者可以使用一个冒号:(简写形式),作用都是运行引号里面的表达式返回运行结果,如下图所示

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

用法2(接受同时进行类型限制):

如果传入的参数类型与指定类型不一致,将会以传入的类型为优先,并发出警告。

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

用法3(接受同时类型限制 默认值指定):

指定类型后还有两个选项,一个是指定是否必要,一个是没有传时的默认值

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

注意:

传进来props元素是不能更改的,否则会报错,如果需要修改应该用一个新的变量去接受它再修改,如下图所示,因为props的优先级是高于return的,所以this.age的内容会提前准备好 

另外,经过测试,这个方法只能在data里面用,无法在setup里面用

Vue3中props和emit怎么使用

emit的使用

setup里面有两个参数props和context

如下图所示,其中props就是和上面说的一样时父组件向子组件传递的信息,如右下图所示

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

现在重点来到emit,emit是context中的一个东西

作用:用来触发父组件里面绑定的函数并可以传参回父组件

如图父组件APP.vue里面的配置,在子组件标签里面绑定了一个函数xxx,并传了一个参数xxx1给了子组件。 并且绑定的函数xxx1还有一个参数要输入。

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

 此时来到子组件这里,子组件里面用一个按钮绑定了一个事件用来触发父组件的事件xxx1并且传了一个字符串“ ”回去,

Vue3中props和emit怎么使用

Vue3中props和emit怎么使用

 最终得到以下的效果,每点击一次子组件StDent里面的按钮,父组件里面的一个字符串属性就会自动添加两个 并显示出来 

Vue3中props和emit怎么使用

emit总结:经过上述例子,我们只需要知道emit是可以让子组件去触发父组件的函数这一点就够了

以上是Vue3中props和emit怎么使用的详细内容。更多信息请关注PHP中文网其他相关文章!

相关标签:
来源:yisu.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板