工作158:vue里面为什么要加key

没有key

 

 <div id="app"><div><input type="text" v-model="name"><button @click="add">添加</button></div><ul><li v-for="(item, i) in list"><input type="checkbox"> {{item.name}}</li></ul>
<script>// 创建 Vue 实例,得到 ViewModelvar vm = new Vue({el: '#app',data: {name: '',newId: 3,list: [{ id: 1, name: '李斯' },{ id: 2, name: '吕不韦' },{ id: 3, name: '嬴政' }]},methods: {add() {//注意这里是unshiftthis.list.unshift({ id: ++this.newId, name: this.name })this.name = ''}}});</script></div>

当选中吕不为时,添加楠楠后选中的确是李斯,并不是我们想要的结果,我们想要的是当添加楠楠后,一种选中的是吕不为

key1.jpg

key3.jpg

有key

 

  <div id="app"><div><input type="text" v-model="name"><button @click="add">添加</button></div><ul><li v-for="(item, i) in list" :key="item.id"><input type="checkbox"> {{item.name}}</li></ul>
<script>// 创建 Vue 实例,得到 ViewModelvar vm = new Vue({el: '#app',data: {name: '',newId: 3,list: [{ id: 1, name: '李斯' },{ id: 2, name: '吕不韦' },{ id: 3, name: '嬴政' }]},methods: {add() {//注意这里是unshiftthis.list.unshift({ id: ++this.newId, name: this.name })this.name = ''}}});</script></div>

同样当选中吕不为时,添加楠楠后依旧选中的是吕不为。

key1.jpg

key2.jpg

可以简单的这样理解:加了key(一定要具有唯一性) id的checkbox跟内容进行了一个关联。是我们想达到的效果

查过相关文档,图例说明很清晰。

vue和react的虚拟DOM的Diff算法大致相同,其核心是基于两个简单的假设
首先讲一下diff算法的处理方法,对操作前后的dom树同一层的节点进行对比,一层一层对比,如下图:

 

before.png

当某一层有很多相同的节点时,也就是列表节点时,Diff算法的更新过程默认情况下也是遵循以上原则。
比如一下这个情况:

 

3297464-ee627869a6714336.jpg

 

我们希望可以在B和C之间加一个F,Diff算法默认执行起来是这样的:

 

3297464-d912523aac5fd108.jpg


即把C更新成F,D更新成C,E更新成D,最后再插入E,是不是很没有效率?

所以我们需要使用key来给每个节点做一个唯一标识,Diff算法就可以正确的识别此节点,找到正确的位置区插入新的节点。

 

3297464-650689b4bd4b9eb6.jpg

 

vue中列表循环需加:key="唯一标识" 唯一标识可以是item里面id index等,因为vue组件高度复用增加Key可以标识组件的唯一性,为了更好地区别各个组件 key的作用主要是为了高效的更新



作者:Nanshannan
链接:https://www.jianshu.com/p/4bd5e745ce95
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/415331.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Activity之间传递bitmap,Observer观察者模式

使用Observer模式进行传递 三个主要类&#xff1a;Observer、Subject、TestObServernotice /*** 作者&#xff1a;created by meixi* 邮箱&#xff1a;15913707499163.com* 日期&#xff1a;2019/5/23 15*/public interface Observer {void update(int id, int intparameter,…

mongodb [main] Automatically disabling TLS 1.0, to force-enable TLS 1.0 specify

今天重启电脑&#xff0c;跑mongodb遇到报错&#xff1a; [main] Automatically disabling TLS 1.0, to force-enable TLS 1.0 specify --sslDisabledProtocols none直接写我的解决方法&#xff1a; 可以先看看mongodb进行占用情况 ps -ef|grep mongod然后直接干掉mongo su…

工作159:根据id传向把对象里面的整个数据传向下个接口

/*绑定第三方账号id*/BindAccount(id) {this.dialogVisible truegetAction("/account/ff_account_list").then(res > {/*通过account_id接收*/this.account_id idthis.BindData res.data.data})}, <el-form class"left-right"><el-form-ite…

Android 人脸识别拍照demo

1、活体与照片。效果&#xff0c;捕获人脸 2、活体人脸识别&#xff1a;https://blog.csdn.net/meixi_android/article/details/88690445 运行效果&#xff1a; 自定义获取人脸view /*** 作者&#xff1a;created by meixi* 邮箱&#xff1a;13164716840163.com* 日期&#x…

多进程进阶

一 multiprocessing模块介绍 python中的多线程无法利用多核优势&#xff0c;如果想要充分地使用多核CPU的资源&#xff08;os.cpu_count()查看&#xff09;&#xff0c;在python中大部分情况需要使用多进程。Python提供了multiprocessing。 multiprocessing模块用来开启子进…

typescript 安装

记录基本的typescript 安装过程。 1、安装 查看最新的版本号 npm show typescript去npm服务器读取包最新的信息&#xff1a; npm install -g typescript使用tsc -v查看版本号 使用npm bin -g查看安装目录 2、使用tsc index.ts就可以将ts文件编译成js文件。 官方在线实练…

工作160:总结VUE几种页面刷新方法

有时候在页面里做了某些操作以后&#xff0c;需要页面刷新一下来重新获取数据。试了几种方法&#xff0c;以下总结&#xff1a; 1、this.$router.go(0) 这种方法页面会一瞬间的白屏&#xff0c;体验不是很好&#xff0c;虽然只是一行代码的事 2、location.reload() 这种也是一样…

linux中修改字符编码

一. ubuntu修改字符编码 1. 添加字符编码&#xff0c;例如zh_CN.UTF-8&#xff0c;有两种方式 方法1&#xff1a;locale-gen zh_CN.UTF-8 #locale-gen命令只在ubuntu中才有 方法2&#xff1a;在/var/lib/locales/supported.d/local中添加字符集zh_CN.UTF-8&#xff0c;保存后…

iview代码片段 去除水平menu底部横线

此处记录日常写的小代码片段 直接使用iview的Menu在底部会出现一条border线&#xff0c;而我的使用场景&#xff0c;不需要border线。所以我就覆盖一下它原来的样式&#xff0c;就可以了。 代码&#xff1a; .ivu-menu-light {&:after {height: 0px !important;}}效果&a…

Android 实现指纹识别demo

demo链接&#xff1a;https://download.csdn.net/download/meixi_android/10796468 1、指纹工具类&#xff1a; /*** 作者&#xff1a;created by meixi* 邮箱&#xff1a;13164716840163.com* 日期&#xff1a;2018/8/30 09*/public class FingerprintManagerUtil {private …

工作161:eachart渲染步骤

第一步 页面 第二步 第三步 方法调用

vue js xlsx 读取 本地 excel

最近在写一个人力资源管理系统&#xff0c;主要目的是将本地的excel文件读取解析&#xff0c;将有效数据传到后台。 下文介绍流程&#xff0c;文末附有参考文章。 1、安装npm包xlsx yarn add xlsx2、结合上传组件和自己写的读取方法readXLSX&#xff0c;可以进行本地excel读…

Android 上下滚动字幕实现

首先values文件夹下添加或创建attrs文件&#xff0c;如下&#xff1a; <?xml version"1.0" encoding"utf-8"?> <resources><!--//垂直滚动字幕--><declare-styleable name"VerticalRollingTextView"><!--文字颜色-…

mongoose获取最高分

我的需求&#xff1a;获取所有成绩中的最高分。 方法&#xff1a;根据分数倒序&#xff0c;查询第一个。 const topScore await Score.find().sort({ score: -1 }).skip(0).limit(1);

工作163:eachrt修改

<template><div><el-card><el-card><time-selects GetTime"GetTime"></time-selects><!--第一步 页面--><div id"main" :style"{ width: 1000px, height: 300px }"></div><div id&quo…

Android 使用ViewPager实现view轮播效果,单个item分页样式,多个item分页样式,横向listview

效果 单个item样式 多个item样式 横向item 自定义viewpager——可开关切换动画 public class NoAnimationViewPager extends ViewPager {public NoAnimationViewPager(Context context) {super(context);}public NoAnimationViewPager(Context context, AttributeSet attrs) …

高德地图开发 怎么去除城市信息

主要通过设置features&#xff0c;里面不要填写point&#xff0c;代表标注即可。 mapConfig {zoom: 17,cityName: MapCityName,pitch: 25,viewMode: 3D,features: [bg, road, building]}官方参考文档&#xff1a;https://lbs.amap.com/api/javascript-api/example/personaliz…

工作164:对父和混入的理解

1点击按钮看编辑事件 2点击编辑之后 对当前页面的方法进行调用 3找到子组件下面的混入方法 create下面引入混入 4找到子组件混入下面的混入方法 5找到下面的getlist方法

Minimum supported Gradle version is 4.1. Current version is 4.0.

Android studio 项目无法编译&#xff0c;报错如下&#xff1a; Minimum supported Gradle version is 4.1. Current version is 4.0. Please fix the projects Gradle settings. Gradle settings 解决方法&#xff1a; 项目build.gradle下 classpath com.android.tools.…