源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

简单理解vue中track-by属性

  • 时间:2022-04-27 01:59 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:简单理解vue中track-by属性
本文实例为大家解析了vue中track-by的属性,供大家参考,具体内容如下 api:[url=http://cn.vuejs.org/guide/list.html#track-by]http://cn.vuejs.org/guide/list.html#track-by[/url] 示例地址:[url=https://jsfiddle.net/stardew/f1eju0ku/5/]https://jsfiddle.net/stardew/f1eju0ku/5/[/url] 无track-by情况:数据修改时,无论值是否被修改,dom都被重新渲染(控制台可以看到) 加入track-by属性:数据修改时,不变数据所在的dom不被重新渲染,已改变的数据所在dom才被重新渲染 track-by的两种使用方法: [b]1. 使用数据中某唯一字段,例如_uid[/b]
<div id="example">
 <p v-for="item in items" track-by="_uid">
 {{item.message}}
 </p>
 <input type="button" value="修改" @click="modify"/>
 <input type="button" value="还原" @click="reduct"/>
</div>
// 初始数据
items: [
 { _uid: '111111', message: '111' },
 { _uid: '222222', message: '222' },
 { _uid: '333333', message: '333' },
 { _uid: '444444', message: '444' },
 { _uid: '555555', message: '555' }
]
// 修改成
modify: function () {
 this.items = [
 { _uid: '111111', message: '111' },
 { _uid: '666666', message: '222' },
 { _uid: '333333', message: '3333' },
 { _uid: '888888', message: '4444' },
 { _uid: '999999', message: '5555' }
 ]
}
渲染效果如下图右(左边无track-by,右边有track-by),_uid和message都不变的情况下,才不被重新渲染,只有第一组符合条件。 [img]http://files.jb51.net/file_images/article/201610/20161026161127745.jpg?2016926161135[/img] [b]2. 使用$index,其它条件同上[/b]
<div id="example">
 <p v-for="item in items" track-by="$index">
 {{item.message}}
 </p>
 <input type="button" value="修改" @click="modify"/>
 <input type="button" value="还原" @click="reduct"/>
</div>
渲染效果如下图右,message的值第一、二条都没改变,所以一、二都没有重新渲染。 [img]http://files.jb51.net/file_images/article/201610/20161026161156347.jpg?201692616123[/img] 模板中同时使用message和_uid时,只有两者都不变的情况下才不重新渲染,如下:
<div id="example">
 <p v-for="item in items" track-by="$index">
 {{item.message}} {{item._uid}}
 </p>
 <input type="button" value="修改" @click="modify"/>
 <input type="button" value="还原" @click="reduct"/>
</div>
[img]http://files.jb51.net/file_images/article/201610/20161026161216012.jpg?2016926161223[/img] 本文已被整理到了《[url=http://www.1sucai.cn/Special/874.htm]Vue.js前端组件学习教程[/url]》,欢迎大家学习阅读。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部