vue props data 父子组件

vue props data 父子组件

子组件通过props接受父组件传入的值

data() {
          return {
              userName: this.userData.name
          }
        },

user.name是String,属于基本数据类型,用它给子组件data中的userName赋值,属于基本数据类型赋值当父组件的user,name发生变化时,子组件中的userName并不会随之变化.
解决的方法: 通过监听props中的值,手动变更局部变量, Watch,Computed

 watch: {
            'userData.name': function (val) { //监听props中的属性
                this.userName = val;
            }
        },
 computed: {
            computedUserName(){
                return this.userData.name
            }
        },

由于data在初始化后深拷贝,props再次变化data并不会刷新,Vue会递归地遍历data所有属性,并使用Object.defineProperty把这些属性全部转换为getter/setter,让data中的属性更具"交互性",以此作为实现双向绑定的基础,这也是为什么只有在组件初始化之初,data中已经声明的属性才具有交互性,即data中的属性变化会引起视图变化,而其他在最初data中没有声明的属性则不会,

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值