关于Cannot read property 'bar' of undefined的问题

message是一个空对象,

    var app = new Vue({
      el: '#app',
      data: {
        message: {},
      },

然后在

<input ... v-model="message.foo">这样不会报错

但再深入一层的时候会报错
<input ... v-model="message.foo.bar">

clipboard.png

请问这怎么解释?

阅读 1.8k
1 个回答

message是一个空对象,message.foo中foo没初始化,为undefined,undefined是不能取值的,也就是不能message.foo.bar

//可以这么写
message: {foo:{}},
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题