使用vue for时为什么要key【推荐】


Posted in Javascript onJuly 11, 2019

前言:

用vue框架写前端代码时经常会用用到v-for这个方法,但使用此方法时vue推荐我们加上一个唯一标识key这是为什么呢?阅读了网上各位大神的文章以及自己的一些理解对这个问题有了新的认识。所以记录下来,若各位看官看到文章里面有错误的地方请指正一下。谢谢各位大佬。

一.diff算法

修改渲染真实的dom会引起整个dom树的重绘和重排。diff算法可以帮助我们只对我们想要修改的部分进行更新而不会引起整个dom树的重绘和重排。 我们先根据dom生成virtual DOM,当virtual Dom上的某个dom节点数据改变后会生成一个新的Vnode.将新生成的Vnode和oldVnode做对比。发现有修改的地方就直接渲染到真实的dom树上。

diff算法一边比较新旧节点的区别一边在真实的dom树上打补丁

二.key的作用

我个人觉得key的作用就是为了快速的找到新节点对应的旧节点。key是给每一个vnode唯一的id,可以依靠key,更准确, 更快的拿到oldVnode中对应的vnode节点。但不使用key时代码也可以运行但是会报warning.为什么呢。

三.不使用key时的执行

例:不使用key 一个数组arr=['1','2','3','4','5','6']

<view v-for='arr'>
    {{item}}
  </view>

上面代码会生成6个div每个div对应的arr中的数字。现在我们将arr变成[0, 1, 2, 3, 7, 8, 9]。更新渲染的步骤时这样的原先div中的1变成0 2变成1以此类推最后新增一个div内容为9。 Vue会通过改变原来元素的内容和增加/减少元素来完成这个改变,因为没有key属性,Vue无法跟踪每个节点,只能通过这样的方法来完成变更。

四.使用key时

例:numbers为[1, 2, 3, 7, 8, 9]

<div v-for="(num, index) in numbers" :key="index">
   {{num}}
  </div>

变成了[0, 1, 2, 3, 7,8,9]新增一个

元素,它的内容为0,并将它插入原先内容为1的元素之前。 在有了key属性之后,Vue会记住元素们的顺序,并根据这个顺序在适当的位置插入/删除元素来完成更新,这种方法比没有key属性时的就地复用策略效率更高。 总体来说,当使用列表渲染时,永远添加key属性,这样可以提高列表渲染的效率,提高了页面的性能。

总结

以上所述是小编给大家介绍的使用vue for时为什么要key属性,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
IE和FireFox(FF)中js和css的不同
Apr 13 Javascript
Javascript学习笔记2 函数
Jan 11 Javascript
浅析js中的浮点型运算问题
Jan 06 Javascript
使用AmplifyJS组件配合JavaScript进行编程的指南
Jul 28 Javascript
js实现选中复选框文字变色的方法
Aug 14 Javascript
Webwork 实现文件上传下载代码详解
Feb 02 Javascript
微信公众号-获取用户信息(网页授权获取)实现步骤
Oct 21 Javascript
jQuery实现图片上传预览效果功能完整实例【测试可用】
May 28 jQuery
jquery获取select选中值的文本,并赋值给另一个输入框的方法
Aug 21 jQuery
区别JavaScript函数声明与变量声明
Sep 12 Javascript
了解javascript中let和var及const关键字的区别
May 24 Javascript
vue 项目@change多个参数传值多个事件的操作
Jan 29 Vue.js
利用Angular7开发一个Radio组件的全过程
Jul 11 #Javascript
vue发送websocket请求和http post请求的实例代码
Jul 11 #Javascript
微信小程序之几种常见的弹框提示信息实现详解
Jul 11 #Javascript
JavaScript表格隔行变色和Tab标签页特效示例【附jQuery版】
Jul 11 #jQuery
vue项目中实现缓存的最佳方案详解
Jul 11 #Javascript
浅入深出Vue之组件使用
Jul 11 #Javascript
elementUI 动态生成几行几列的方法示例
Jul 11 #Javascript
You might like
用php实现的获取网页中的图片并保存到本地的代码
2010/01/05 PHP
Laravel中使用阿里云OSS Composer包分享
2015/02/10 PHP
PHP时间和日期函数详解
2015/05/08 PHP
php往mysql中批量插入数据实例教程
2018/12/12 PHP
php生成HTML文件的类方法
2019/10/11 PHP
用js解决数字不能换行问题
2010/08/10 Javascript
js解析与序列化json数据(二)序列化探讨
2013/02/01 Javascript
hover的用法及live的用法介绍(鼠标悬停效果)
2013/03/29 Javascript
animate动画示例(泪奔的小孩)及stop和delay的使用
2013/05/06 Javascript
node.js中的http.response.getHeader方法使用说明
2014/12/14 Javascript
javascript数据结构与算法之检索算法
2015/04/04 Javascript
JS克隆,属性,数组,对象,函数实例分析
2016/11/26 Javascript
原生js实现轮播图的示例代码
2017/02/20 Javascript
关于meta viewport中target-densitydpi属性详解(推荐)
2017/08/18 Javascript
vue-cli项目代理proxyTable配置exclude的方法
2018/09/20 Javascript
基于JS实现数字动态变化显示效果附源码
2019/07/18 Javascript
微信小程序实现写入读取缓存详解
2019/08/30 Javascript
node.js express框架实现文件上传与下载功能实例详解
2019/10/15 Javascript
python字符串对其居中显示的方法
2015/07/11 Python
python常见排序算法基础教程
2017/04/13 Python
python发送邮件实例分享
2017/07/28 Python
python实现对输入的密文加密
2019/03/20 Python
对python tkinter窗口弹出置顶的方法详解
2019/06/14 Python
python如何爬取网站数据并进行数据可视化
2019/07/08 Python
Python之虚拟环境virtualenv,pipreqs生成项目依赖第三方包的方法
2019/07/23 Python
使用 pytorch 创建神经网络拟合sin函数的实现
2020/02/24 Python
基于Keras中Conv1D和Conv2D的区别说明
2020/06/19 Python
Python爬取12306车次信息代码详解
2020/08/12 Python
pandas处理csv文件的方法步骤
2020/10/16 Python
Html5画布_动力节点Java学院整理
2017/07/13 HTML / CSS
英国探险旅游专家:Explore
2018/12/20 全球购物
英国领先的在线高尔夫商店:Scottsdale Golf
2019/08/26 全球购物
2014年教师节讲话稿5篇
2014/09/10 职场文书
毕业横幅标语
2014/10/08 职场文书
会计人员岗位职责
2015/02/03 职场文书
法制主题班会教案
2015/08/13 职场文书