Vuejs在数组中的项目上使用v-model时,数据绑定不起作用

时间:2017-05-18 16:28:46

标签: vuejs2

Vue.js的新手。不知道我在哪里错了。我有一个动态的用户列表,您可以添加。我还有一个选择,我希望保持最近对用户的任何模型更改。但是,当我更改用户信息时,选择不会更新。我附上了代码和小提琴。

HTML:

<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.0.3/vue.js"></script>
<div id="app">
  <h1>Users</h1>
  <div v-for="user in users">
    User ID: <input type="text" v-model="user.id" /><br /> 
    First Name: <input type="text" v-model="user.firstName" /><br />
    Last Name: <input type="text" v-model="user.lastName" />
    <br />
  </div>
  <input type="button" value="Add User" v-on:click="addUser" />
  <br /><br />
  This select should stay synced with what is entered above<br />
  <select>
    <option v-for="user in users" v-bind:value="user.firstName">{{user.firstName}} {{user.lastName}}</option>
  </select>
</div>

JavaScript的:

var app = new Vue({
    el: "#app",
    data: {
        users: [{}]
    },
    methods: {
        addUser: function() {
        this.users.push({});
      }
    }
});

小提琴:https://jsfiddle.net/rmekuuc3/

1 个答案:

答案 0 :(得分:3)

这是Vue中的change detection caveat。当您将属性添加到该对象上尚未存在的对象时,Vue无法检测到。相反,你应该像这样写代码。

var app = new Vue({
    el: "#app",
    data: {
        users: [{id: null, firstName: null, lastName: null}]
    },
    methods: {
        addUser: function() {
        this.users.push({id: null, firstName: null, lastName: null});
      }
    }
});

更新了fiddle