用途:当有一种类型的组件需要被使用多次,每一次的调用都只是特定的地方不同,就好像一张个人简介表,每次填的人的信息都不同,但是结构都是一样的。
在父组件里面引入子组件,通过子组件的标签属性传递参数,在子组件里面定义一个props选项进行接收使用,要注意在子组件里面不需要在props以外的地方事先定义
在上面可以看见传进来的age是一个字符串类型,如果想要让传进来的值自动加1不能在子组件使用时里面+1,如下图所示会变成字符串加法241
正确的解决方案是在父组件进行传参时就要进行使用v-bind进行动态绑定,又或者可以使用一个冒号:(简写形式),作用都是运行引号里面的表达式返回运行结果,如下图所示
如果传入的参数类型与指定类型不一致,将会以传入的类型为优先,并发出警告。
指定类型后还有两个选项,一个是指定是否必要,一个是没有传时的默认值
传进来props元素是不能更改的,否则会报错,如果需要修改应该用一个新的变量去接受它再修改,如下图所示,因为props的优先级是高于return的,所以this.age的内容会提前准备好
另外,经过测试,这个方法只能在data里面用,无法在setup里面用
setup里面有两个参数props和context
如下图所示,其中props就是和上面说的一样时父组件向子组件传递的信息,如右下图所示
现在重点来到emit,emit是context中的一个东西
作用:用来触发父组件里面绑定的函数并可以传参回父组件
如图父组件APP.vue里面的配置,在子组件
此时来到子组件这里,子组件里面用一个按钮绑定了一个事件用来触发父组件的事件xxx1并且传了一个字符串“ ”回去,
最终得到以下的效果,每点击一次子组件StDent里面的按钮,父组件里面的一个字符串属性就会自动添加两个 并显示出来
emit总结:经过上述例子,我们只需要知道emit是可以让子组件去触发父组件的函数这一点就够了
以上是Vue3中props和emit怎么使用的详细内容。更多信息请关注PHP中文网其他相关文章!