5 列表渲染的指令v-for

  • v-for on Array / Object / String / Number
  • v-for on template
  • v-for on expression
  • v-for with key

v-for指令可以对一个可迭代对象进行遍历,将指定的值循环输出显示。

基本语法形式:

v-for = "item in arr"    OR   v-for = "(item, index) in arr"
v-for = "value in obj" OR v-for = "(value, key, index) in obj"
v-for = "char in str" OR v-for = "(char, index) in str"
v-for = "n in num"
v-for = "item in expression" expression === Array / Object / str / num

以上 index, key都是可省略,并注意参数的顺序:值在前,序号或键值在后。

in 改为 of 同样有效,如 v-for = "item of arr"

点击查看DEMO: v-for on Array/Object/String/Number/template

//js
new Vue({
el: "#app",
data: {
arr: ["HTML", "CSS", "JS", "JQ", "VUE"],
obj: {
Rocket: "McGrady",
Lakers: "Kobe",
Mavericks: "Nowitzki",
},
str: "abc",
num: 3
}
})
<!-- Array -->
<li v-for = "item in arr">{{ item }}</li>
<li v-for = "(item, index) in arr">{{ index + "-" + item }}</li>
<li v-for = "(item, index) of arr">{{ index + "-" + item }}</li>
<!-- Object -->
<li v-for = "value in obj">{{ value }}</li>
<li v-for = "(value, key) in obj">{{ key + "-" + value }}</li>
<li v-for = "(value, key, index) in obj">{{index + "-" + key + "-" + value }}</li>
<!-- String -->
<li v-for = "char in str">{{ char }}</li>
<li v-for = "(char, index) in str">{{ index + "-" + char }}</li>
<!-- Number -->
<li v-for = "n in num">{{ n }}</li>
<!-- v-for on template -->
<h3>super star in NBA team</h3>
<template v-for = "(starName, teamName) in obj">
<p>team name: {{ teamName }}</P>
<p>super star: {{ starName }}</p>
</template>
 使用`template`包裹元素块可以让文档避免太多无意义块元素,如太多只作包裹性质的`div`

点击查看DEMO: v-for on expression

<!-- v-for on expression -->
<ul id="app">
<!-- v-for 渲染计算属性的值,偶数列表 -->
<li v-for="even in evenNumbers">{{ even }}</li>
<br/> <!-- v-for 渲染方法oddNumber执行返回的奇数列表 -->
<li v-for="odd in oddNumbers(numbers)">{{ odd }}</li>
</ul>
new Vue({
el: "#app",
data: {
numbers: [1,2,3,4,5,6,7,8,9]
},
computed: {
evenNumbers() { return this.numbers.filter(item => item % 2 === 0)}
},
methods: {
oddNumbers(arr) { return arr.filter(item => item % 2 !== 0)}
}
})

key 标识列表元素的唯一性

同上一节中讲到的v-if中的key作用一样,如果在v-for的数据发生了变化,vue并不是重新生成并渲染所有元素,而是智能找到需要更改的元素,并只更新这些元素,其它元素“就地复用”。这是VUE的差异对比机制控制的(virtual DOM和DOM diff会在下一阶段总结)。

刻意采用这种默认机制可以获取页面渲染性能的提升,但官方仍然建议不要使用默认做法,正确做法是加上key,以便对每个列表元素提供一个可跟踪的唯一属性值,在大型项目中或组件列表渲染中更为高效。

 `key`应该是一个字符串或数值类型的唯一值。不要使用对象或数组之类的`非原始类型值`,如不要用下标`index`作为 v-for 的 key。

点击查看DEMO: v-for with key

 <!-- has key -->
<div id="app">
<template>
<demo-key
v-for="(item, i) of items"
@click.native="items.splice(i,1)">
{{ item }}
</demo-key>
</template>
</div>
<!-- no key -->
<div id="app">
<template>
<demo-key
v-for="(item, i) of items"
:key="item"
@click.native="items.splice(i,1)">
{{ item }}
</demo-key>
</template>
</div>
// js
const randomColor = () => `hsl(${Math.floor(Math.random() * 360)},75%, 85%)`
const DemoKey = {
template: `<p :style="{backgroundColor: color}"><slot></slot></p>`,
data: () => ({
color: randomColor()
})
} new Vue({
el: "#app",
data: {
items: ["one", "two", "three", "four", "five"]
},
components: {
DemoKey
}
})

vue-learning:5-template-v-for的更多相关文章

  1. vue报错:Component template should contain exactly one root element. If you are using v-if on multiple elements, use v-else-if to chain them instead.

    在.vue文件中引入了 element-ui 的 table 和 pagination 组件后,报错:Component template should contain exactly one roo ...

  2. 小白学习VUE第二课:环境搭建 VUE Node.js VSCode template模板

    环境搭建 VUE Node.js VSCode template模板: 首先安装node:http://www.runoob.com/nodejs/nodejs-install-setup.html ...

  3. Vue系列:如何将百度地图包装成Vue的组件

    主要分解为如下步骤: (1)在html文件中引入百度地图, <script type="text/javascript" src="http://api.map.b ...

  4. Vue.js:轻量高效的前端组件化方案

    转发一篇尤老师对vue.js的介绍,了解vue.js的来龙去脉.不过现在已经是2.0了,也有添加一些新的东西,当然有些东西也改了. Vue.js:轻量高效的前端组件化方案 Vue.js 是我在2014 ...

  5. Deep learning:四十六(DropConnect简单理解)

    和maxout(maxout简单理解)一样,DropConnect也是在ICML2013上发表的,同样也是为了提高Deep Network的泛化能力的,两者都号称是对Dropout(Dropout简单 ...

  6. Vue.js:轻量高效的前端组件化方案(转载)

    摘要:Vue.js通过简洁的API提供高效的数据绑定和灵活的组件系统.在前端纷繁复杂的生态中,Vue.js有幸受到一定程度的关注,目前在GitHub上已经有5000+的star.本文将从各方面对Vue ...

  7. 转载 Deep learning:六(regularized logistic回归练习)

    前言: 在上一讲Deep learning:五(regularized线性回归练习)中已经介绍了regularization项在线性回归问题中的应用,这节主要是练习regularization项在lo ...

  8. 组件嵌套时报:Component template should contain exactly one root element. If you are using v-if on multiple elements, use v-else-if to chain them instead.

    在组件嵌套的过程中,报了一个错误: 这里报错的原因是:vue的组件(模板)只能有一个根节点,即.vue文件中的<template>标签下只能有一个子元素. 因此,建议大家在写.vue组件的 ...

  9. 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 二十二║Vue实战:个人博客第一版(axios+router)

    前言 今天正式开始写代码了,之前铺垫了很多了,包括 6 篇基础文章,一篇正式环境搭建,就是为了今天做准备,想温习的小伙伴可以再看看<Vue 基础入门+详细的环境搭建>,内容很多,这里就暂时 ...

  10. 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 二十三║Vue实战:Vuex 其实很简单

    前言 哈喽大家周五好,马上又是一个周末了,下周就是中秋了,下下周就是国庆啦,这里先祝福大家一个比一个假日嗨皮啦~~转眼我们的专题已经写了第 23 篇了,好几次都坚持不下去想要中断,不过每当看到群里的交 ...

随机推荐

  1. Directx11教程(34) 纹理映射(4)

    原文:Directx11教程(34) 纹理映射(4)     本篇教程中,我们尝试在myTutorialD3D_27中改变采样状态描述符的各种设置,看纹理贴图的方式有什么变化. 原始的代码是:     ...

  2. Leetcode811.Subdomain Visit Count子域名访问计数

    一个网站域名,如"discuss.leetcode.com",包含了多个子域名.作为顶级域名,常用的有"com",下一级则有"leetcode.com ...

  3. 洛谷P2607 骑士

    题目描述 Z国的骑士团是一个很有势力的组织,帮会中汇聚了来自各地的精英.他们劫富济贫,惩恶扬善,受到社会各界的赞扬. 最近发生了一件可怕的事情,邪恶的Y国发动了一场针对Z国的侵略战争.战火绵延五百里, ...

  4. hdu1730 尼姆博弈

    抽象一下把距离当做石子个数.虽然在这里石子个数可以增加,但是不管怎么增加,不会影响结果,因为你增加了,必须会有减少的. 所以类似取石子,观察平衡状态,如果(x2-x1-1)^...==0,必输. wa ...

  5. HTTP请求模型

    HTTP请求模型 HTTP请求模型 一.连接至Web服务器一个客户端应用(如Web浏览器)打开到Web服务器的HTTP端口的一个套接字(缺省为80). 例如:http://www.myweb.com: ...

  6. ELK之开心小爬爬

    1.开心小爬爬 在爬取之前需要先安装requests模块和BeautifulSoup这两个模块 ''' https://www.autohome.com.cn/all/ 爬取图片和链接 写入数据库里边 ...

  7. python 替换字符串的方法replace()、正则re.sub()

    一.replace()函数1用字符串本身的replace方法: a = 'hello word' b = a.replace('word','python') print b   1 2 3 二.re ...

  8. 17-1 djanjo进阶-路由,视图,模板

    一 路由系统进阶(urls.py) 动态路由 urls.py中通过正则表达式的分组匹配,捕获用户访问的url中的值,传递给视图函数1 分组匹配(通过圆括号): 相当于给视图函数传递 位置参数 例子: ...

  9. ASCII代码表

    >>ASCII代码表<<

  10. CREATE OR REPLACE FUNCTION

    CREATE OR REPLACE FUNCTION SF_Taishou_Ksai_Date(v_receiptNum IN CHAR,                                ...