飞利浦·斯塔克|Vue子组件向父组件传参(事件传参)( 二 )
)</script>
示例结果
子组件通过自定义事件改变父组件数据.png
最后父组件数据一变子组件显示结果自然变化
我们也知道$emit
方法在触发自定义事件的时候还可以给自定义事件传参 这样就可以实现子组件像父组件传参
3. 子组件向父组件传参上一小节我们是在子组件中通过自定义事件触发父组件中的函数 在父组件中修改数据
同样我们也可以在子组件中修改数据然后将修改后的数据通过自定义事件传参的方式传递给父组件函数在父组件函数中直接用子组件传过来修改后的数据直接替换父组件中的数据
示例代码如下:
【飞利浦·斯塔克|Vue子组件向父组件传参(事件传参)】<div id=\"app\">
<!-- 使用组件 -->
<!-- 3.在子组件中绑定自定义事件 将父组件的方法绑定为自定义事件的处理函数-->
<my-component
:clicks=\"clicks\"
@count=\"handleParentClick\"
></my-component></div><!-- 组件模板 --><template id=\"MyComponent\">
<div>
被点击了{{clicks次 <!-- 1. 子组件通过原生click事件触发子组件自己的函数 -->
<button @click=\"handleClick\">点击</button>
</div></template><script>
// 组件选项对象
let MyComponent = {
props:[\"clicks\"
template: `#MyComponent`
data(){
return {
count: this.clicks
methods:{
handleClick(){
// 2.子子组件函数中触发自定义事件
// 2.1 在触发自定义事件的时候向自定事件传参
this.count+=2
this.$emit(\"count\"this.count)
// 实例中注册组件
const vm = new Vue({
el:\"#app\"
data: {
clicks:0
components: {
\"MyComponent\": MyComponent
methods:{
handleParentClick(count){
// 4. 在父组件函数中修改父组件中的数据
// 4.1 接受自定义事件触发时传递的参数
console.log(count)
this.clicks = count
)</script>
- 飞利浦·斯塔克|最便宜的小米 12 来了,2000 块左右
- 飞利浦·斯塔克|「手慢无」泰坦军团 C30SK PRO显示器 秒杀1299元
- 飞利浦·斯塔克|集五福卡又来了!支付宝提前开始布局了,神秘福卡限时领
- 应用案例集锦丨飞利浦数字标牌,让品牌形象锋芒毕露
- 飞利浦·斯塔克|原价买显卡时代即将来临!英伟达:今年火力全开加大显卡产能
- 飞利浦新款首发K歌回音壁B5856 在家也要热血KTV
- 作为一个很懒的RGB爱好者|飞利浦huesync家庭影院氛围灯
- 飞利浦·斯塔克|所有互联网公司都在赔钱卖菜,真正的原因你绝对想不到!
- 飞利浦·斯塔克|《2021中国互联网广告数据报告》发布,受反垄断监管影响,阿里巴巴、腾讯广告收入增长放缓,字节跳动或赶超
- 飞利浦·斯塔克|世界是虚拟的吗?马斯克:我们活在真实世界的概率不到十亿分之一