vue中更改数组中属性,在页⾯中不⽣效的解决⽅法
问题描述:
使⽤vue的⽅法获取了数组数据,获取数据后为每个数据增加edit属性,初始值均为false,其⽬的是为了当点击列表中的编辑按钮时,控制保存与不保
存的按钮的出现与消失,结果当更改数组中的edit属性后,页⾯并没有如预期的那样当edit为true时页⾯显⽰更改状态,当edit为false时为不更改状态
解决⽅案:
edit是在通过post⽅法获取数据后增加到vue的data数据中的属性,⼀开始我的做法先将接收到的数据赋值到vue的data中,再对vue的data中的数据增加edit属性,这样在改变edit的之后,虽然在js中使⽤console.log可以看到该值已经发⽣变化,但页⾯中的data值并没有发⽣变化。
正确的做法应该是先为接收到的数据初始化edit属性,再将处理后的数据赋值给vue的data。
代码如下
<tbody>
<tr v-for="(book,index) in bookList">
<td>
<span v-on:click="book.edit=true" v-show=" !book.edit">{{derIndex}}</span> //如果edit属性为false,则该span出现
<input v-show="book.edit" /> //如果edit属性为true,则该input出现
</td>
<td>
<a v-show="book.edit" v-on:click="book.edit=false" class="btn btn-primary btn-sm"> //如果edit属性为true,出现不保存(x)按钮
<i class="glyphicon glyphicon-remove" aria-hidden="true"></i>
</a>
<a v-show="book.edit" v-on:click="save(book)" class="btn btn-primary btn-sm"> //如果edit属性为true,
出现保存(√)按钮
<i class="glyphicon glyphicon-ok" aria-hidden="true"></i>
</a>
</td>
</tr>
</tbody>
<script>
var politics = new Vue({
el:"#politics",
data:{
bookList:[]
},
methods:{
getBookList: function (offset, limit, CatalogueID, searchKey, resId) {
this.limit = limit;
this.offset = offset;
this.CatalogueID = CatalogueID;
this.searchKey = searchKey;
this.$("/BookAdmin/getBookList?offset=" + this.offset + "&limit=" + this.limit + "&CatalogueID=" + this.CatalogueID + "&searchKey=" + this.searchKey+"&resId="+sId)    .then(function (resp) {
resp.data.books.forEach(function (o, i) {
o.edit = false;
})
this.bookList = resp.data.books; // 赋值必须写在属性初始化的后⾯,否则改edit不能使页⾯属性变化
this.bookTotalCount = alCount;
var pageNo = this.offset / this.limit + 1;
vue逗号分割的字符串转数组var totalPage = il(this.bookTotalCount / this.limit);
divpager(pageNo, totalPage, this.bookTotalCount, this.CatalogueID, this.searchKey, sId);
})
}
}
})
</script>
以上这篇vue中更改数组中属性,在页⾯中不⽣效的解决⽅法就是⼩编分享给⼤家的全部内容了,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。