v-model实现父组件和子组件之间的传值

父组件中设置为:

<template>
  <div>
    <!-- msg变量传给Child的value属性(props) -->
    <Child v-model="msg"></Child>
    外面{{msg}}
  </div>
</template>

import Child from './Child'
export default {
  data () {
    return {
      msg: '123'
    }
  },
  components: {
    Child
  }

子组件设置为

<template>
  <div>
      我是个子组件: {{ value }}
      <button @click="btn">点击修改value</button>
  </div>
</template>

export default {
  props: ['value']
  methods: {
    btn () {
      // 外面v-model已经把@input内部实现了, 会把你传出去的值直接给v-model的变量
      this.$emit('input', '子组件传出来的值')
    }
  }
}

注意:父组件传递过来的值,名字必须为value,如果设置的为其他名字,则接受不到数据

如果传递给子组件变量是基础类型--------v-model双向数据绑定(遵守单向数据流)

如果是引用数据类型:不要违反单向数据流,原因:如果把这个引用类型传给孩子, 有一个孩子改变, 其他的孩子都同步了(不知道谁改的...)

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值