Vue父子组件数据双向绑定

Vue父子组件数据双向绑定

最近没有写新项目,天天看零零碎碎的博客,感觉还没啥进步。前些天更新版本的时候发现双向绑定的知识点都忘了,赶紧记下来!

  • 所有的 prop 都使得其父子之间形成了一个单向下行绑定,父级 prop 的更新会向下流动到子组件中,但是反过来则不行
  • 2.3.0+ 新增 .sync 修饰符,以 update:my-prop-name 的模式触发事件实现上行绑定,最终实现双向绑定

上代码

父组件内容:

<child-compoment :fatherValue="value"></child-compoment>

<template>
  <div>
  	value:{{value}}
    <child :fatherValue.sync="value" ></child>
  </div>
</template>
<script>
import ChildCompoment from './ChildCompoment'  //引入Child子组件
export default {
  components: { ChildCompoment },
  data() {
    return {
      value: ''
    }
  }
}
</script>

子组件内容:

<template>
  <div>
      <button @click="handler">click</button>
  </div>
</template>

<script>

export default {
  props: {
    fatherValue: {
      required: true
    }
  },
  data () {
    return {}
  },
  methods: {
  	handler(){
  		// 设置值为 test
  		this.$emit('update:fatherValue', 'test')
  	}
  }
}
</script>

Vue3 才摸索一段时间,Vue2 的知识都忘了。我屮艸芔茻,阔怕阔怕。是时候再去看一遍文档了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值