- 概念
v-for
指令基于一个数组来渲染一个列表。v-for
指令需要使用 item in items
形式的特殊语法,其中 items
是源数据数组,而 item
则是被迭代的数组元素的别名。
2. 代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script>
</head>
<body>
<div id="app">
<ul>
<li v-for="(value,index) in datalist " :key="index">
{{value}}--{{index}}
</li>
</ul>
</div>
<script>
var vm = new Vue({
el:'#app',
data:{
datalist:['aaa','bbb','ccc']
}
})
</script>
</body>
</html>
最后输出li列表aaa,bbb,ccc
3. key
当 Vue 正在更新使用 v-for
渲染的元素列表时,它默认使用“就地更新”的策略。如果数据项的顺序被改变,Vue 将不会移动 DOM 元素来匹配数据项的顺序,而是就地更新每个元素,并且确保它们在每个索引位置正确渲染。
这个默认的模式是高效的,但是只适用于不依赖子组件状态或临时 DOM 状态 (例如:表单输入值) 的列表渲染输出。
为了给 Vue 一个提示,以便它能跟踪每个节点的身份,从而重用和重新排序现有元素,你需要为每项提供一个唯一 key
attribute。
建议尽可能在使用 v-for
时提供 key
attribute,除非遍历输出的 DOM 内容非常简单,或者是刻意依赖默认行为以获取性能上的提升。
因为它是 Vue 识别节点的一个通用机制。
key的做用:
- 跟踪每个节点的身份,从而重用和重新排序现有元素
- 理想的key是每项都有且唯一的id。
4. 数组更新检测
Vue 将被侦听的数组的变更方法进行了包裹,所以它们也将会触发视图更新。这些被包裹过的方法包括:
push() pop() shift() unshift() splice() sort() reverse()
使用以上方法变更数组可以检测到数组变动。
filter() slice() concat() 这三种方法也可以,本质上是用新数组替换旧数组。
注意:
使用数组的索引赋值是不能检测到数组变化的,如:
vm.items[index] =newVal;
解决方法:
Vue.set(vm.items,index,newVal);
或则 vm.items.splice(index,num,newVal);