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({});
}
}
});
答案 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。