为什么你需要在用 Vue 渲染列表数据时指定 key
本文改写整理自一篇博文,原文链接如下:
Why you should use the key directive in Vue.js with v-for
Application state and DOM state
要回答这个问题,我们先要了解一下以下两个概念:应用状态(Application state)和 DOM 状态(DOM state),先创建一个简单的 Vue 组件如下(Vue 3):
<script setup>
import { reactive } from "@vue/reactivity"
let list = reactive([
{
name: 'name1',
likes: '炸鸡汉堡',
id: 'item1',
},
{
name: 'name2',
likes: '红茶枸杞',
id: 'item2'
}
]);
// 用来调换列表顺序
const changeOrder = () => {
let list2 = [...list];
list[0] = list2[1];
list[1] = list2[0];
}
</script>
<template>
<ul class="list">
<li v-for="item in list"> <!-- 没有绑定 key -->
{{ item.name }} <br>
{{ item.likes }}
<input type="text">
</li>
</ul>
<button @click="changeOrder">改变列表顺序</button>
</template>
<style scoped>
button {
margin-top: 1em;
}
</style>
此时界面如下:

我们可以在“红茶枸杞”后输入文本,例如“好喝”

然后点击“改变列表顺序”,我们可以看到界面变成这个样子:

很奇怪是不是?让我们来看看是为什么?
在这个例子里,每一条数据显示的 name 和 likes 的内容是从应用的状态(application state)里获得的,其余部分的内容没有和 Vue 实例里的任何数据绑定,因此是独立于应用状态的,所以你在 input 输入框内输入的东西是临时储存于 DOM 状态(DOM State)内的
In-place patch strategy
我们已经知道了应用状态和 DOM state 的区别,现在我们要理解一下 Vue 在渲染列表数据时所采取的策略,根据 Vue 的官网介绍:
When Vue is updating a list of elements rendered with v-for, by default it uses an "in-place patch" strategy. If the order of the data items has changed, instead of moving the DOM elements to match the order of the items, Vue will patch each element in-place and make sure it reflects what should be rendered at that particular index.
也就是说,在应用状态有变化的时候(例如列表的顺序变了),Vue 会尽可能小地减少 DOM 操作,尽可能地重用 DOM, 在上述例子里,Vue 只会更新 DOM 元素内的状态,而不是真的把两个 <li> 标签交换位置,以此来反映应用状态的变化,我们可以通过下面这张 gif 来直观地感受下:

在上面的例子里,我们在输入框内输入的内容没有和如何应用状态绑定过,只是临时的 DOM 状态,又由于 Vue 的渲染策略,导致了我们在改变元素顺序时,input 并没有如我们想象中那样移动。
解决办法:添加 key
<li v-for="item in list" :key="item.id"> <!-- 绑定了 key -->
此时再点击更改列表顺序的按钮,可以看到 input 也会随着一起移动:

这里有一点需要注意,如果我们用数组的下标作为 key 的值,input 仍是不会移动的,数组的下标不是应用状态的一部分
<li v-for="(item, idx) in list" :key="idx"> <!-- 绑定了 key, 使用数组下标 -->

为什么你需要在用 Vue 渲染列表数据时指定 key的更多相关文章
- 【vue】渲染大量数据时性能优化
对应vue渲染大量数据时可以考虑下面几点: 1. 异步渲染组件:因为组件渲染太多,影响页面的渲染时间,所有可以延迟组件渲染,可以考虑v-if处理 2. 可以使用虚拟滚动的组件:参考使用这个插件 vue ...
- React.js 小书 Lesson13 - 渲染列表数据
作者:胡子大哈 原文链接:http://huziketang.com/books/react/lesson13 转载请注明出处,保留原文链接和作者信息. 列表数据在前端非常常见,我们经常要处理这种类型 ...
- 获取列表数据时,getList 设置默认参数:getList(page = 1),点击分页及前往时,传page参数,其他使用page的默认值:1
获取列表数据时,getList 设置默认参数:getList(page = 1),点击分页及前往时,传page参数,其他使用page的默认值:1
- Vue渲染列表,在更新data属性后,列表未更新问题
初始化代码如下var tableModel = new Vue({el: '#datatable',data: {items: listData}}); 当我对列表操作时,listData=>n ...
- 好客租房41-react组件基础综合案例-渲染列表数据
1渲染列表 在state定义数据 进行数据渲染 //导入react import React from 'react' import ReactDOM from 'react-dom' //导入组件 ...
- Vue 基本列表 && 数据过滤与排序
1 <!DOCTYPE html> 2 <html> 3 <head> 4 <meta charset="UTF-8" /> 5 & ...
- vue再页面渲染json数据时没有显示
对象点属性不能获取数据. 原因: 在创建数据对象时我使用了k,v方式:tempMap['category '] = this.category[i].label 如果在创建数据时使用的k,v方式,那么 ...
- vue v-for 遍历循环时的key值的报错
问题如下: [Vue warn] Avoid using non-primitive value as key, use string/number value instead. non-primit ...
- Vue.js的列表数据的同步更新方法
这次给大家带来Vue.js的列表数据的同步更新方法,Vue.js列表数据同步更新方法的注意事项有哪些,下面就是实战案例,一起来看一下. 数组的 push(),pop(),shift(),unshift ...
随机推荐
- C#使用 WebRequest 异步获取网页并自动忽略SSL证书
C#使用 WebRequest 模拟浏览器请求访问网页并自动忽略HTTPS安全证书 以下两个C#异步方法,封装了WebRequest请求,支持忽略SSL证书. 作者:张赐荣 1.Get请求 ...
- CentOS7 下 ldap 部署
环境准备 # 关闭防火墙以及selinux,生产环境中,以实际需求为准 [root@localhost ~]# hostnamectl --static set-hostname ldap-serve ...
- mysql数据库怎么存入emoji表情
第一步 设置数据库字符编码为utf8mb4_general_ci 设置相应表字段字符编码为utf8mb4_general_ci 第二步 设置my.cnf增加以下配置信息 [client] defau ...
- Vue2.0源码学习(2) - 数据和模板的渲染(下)
vm._render是怎么实现的 上述updateComponent方法调用是运行了一个函数: // src\core\instance\lifecycle.js updateComponent = ...
- 记一次慢查询优化sql
sql语句优化(慢查询日志) 最近,旧系统向新系统迁移工程刚刚结束.开发完成后,测试阶段也是好好休息了一把.接到一个需求,由于内部员工使用的网站部分功能加载时间很长,所以需要去优化系统的一些功能.大致 ...
- [题解]UVA10026 Shoemaker's Problem
链接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&am ...
- 如何将k8s中的某些节点单独、仅给某些应用来使用
1.概述 在k8s集群的使用场景中有这样的一种情况,某些机器只给某些特殊的应用来使用.那么,这个时候,需要有以下的2个条件来进行保障: 节点不允许其他的pod来使用 应用只允许被调度到该节点上 2.实 ...
- 企业没有大数据技术?选择这款BI工具
无论是网络时代的传统营销还是大数据营销,营销人员的任务之一就是找到目标客户,实现自己的营销目标.而我们说的大数据营销只不过是营销的工具发生了变化,营销的本质和目标是不变的. 就目前而言,现在的大数据 ...
- 国内外主流5款doshboard软件比较和对比
大数据行业随着互联网的蓬勃发展中也越来越被人们看好,但是从事大数据行业的数据分析师经常会谈到dashboard,很多人就会疑惑什么是dashboard,下面就来了解一下Doshboard的发展. da ...
- 自助BI工具:Tableau和Smartbi的对比(上)
商业智能(BI)和分析平台长期以来一直是商业的重要组成部分,但由于自助BI工具的兴起,在数据科学家和数据库管理员的支持下,分析的责任已经从IT转移到了商业分析师身上. 因此,BI已经从生成月度报告的记 ...