[TOC]
## 列表渲染指令v-for
我们用 v-for 指令根据一组数组的选项列表进行渲染。v-for 指令需要使用 item in items 形式的特殊语法,items 是源数据数组并且 item 是数组元素迭代的别名。v-for 还支持一个可选的第二个参数index为当前项的索引。
示例:
```
<!-- 在这种嵌套循环的时候, index 和 itemIndex 这种索引是必须指定,且别名不能相同,正确的写法如下 -->
<template>
<scroll-view v-for="(card, index) in list" :key="index">
<view v-for="(item, itemIndex) in card" :key="itemIndex">
{{item.value}}
</view>
</scroll-view>
</template>
```
为了能跟踪每个节点的身份,从而重用和重新排序现有元素,你需要为每项提供一个唯一 key 属性。理想的 key 值是每项都有的且唯一的 id,它的工作方式类似于一个属性,所以你需要用 v-bind 来绑定动态值。
> uni-app中嵌套列表渲染,必须指定不同的索引!需要填写:key="xx",或者v-bind:key=”xx”。
以下的示例演示了如何结合v-show指令和v-for指令条件输出,并使用Flex布局生成表格输出。
> 本例演示了Flex布局的垂直居中和水平居中,表格的每一列占屏幕宽度的1/3。
* [ ] pages/lab/gramma/vfor.vue
```
<!-- pages/lab/gramma/vfor.vue -->
<template>
<view style="flex-direction: column; flex: 1; justify-content: center;">
<view>
<view class="table-item">索引</view>
<view class="table-item">姓名</view>
<view class="table-item">年龄</view>
</view>
<block v-for="(item, index) in students" :key="index">
<view v-if="item.age >=20">
<view class="table-item">{{index}}</view>
<view class="table-item">{{item.name}}</view>
<view class="table-item">{{item.age}}</view>
</view>
</block>
</view>
</template>
<script>
export default {
data() {
return {
students: [{
name: "张三",
age: 18
},
{
name: "李四",
age: 20
},
{
name: "王五",
age: 21
}
]
}
}
}
</script>
<style>
view {
display: flex;
flex-direction: row;
}
.table-item {
display: flex;
flex: 1;
justify-content: center;
align-items: center;
}
</style>
```
![](https://box.kancloud.cn/062e94705309cd1273dcf2b4acfa2d7a_914x779.png)
### [key](https://uniapp.dcloud.io/use?id=key)
如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态(如`<input>`中的输入内容,`<switch>`的选中状态),需要使用`:key`来指定列表中项目的唯一的标识符。
`:key`的值以两种形式提供
* 使用`v-for`循环`array`中`item`的某个`property`,该`property`的值需要是列表中唯一的字符串或数字,且不能动态改变。
* 使用`v-for`循环中`item`本身,这时需要`item`本身是一个唯一的字符串或者数字
当数据改变触发渲染层重新渲染的时候,会校正带有`key`的组件,框架会确保他们被重新排序,而不是重新创建,以确保使组件保持自身的状态,并且提高列表渲染时的效率。
**如不提供`:key`,会报一个`warning`, 如果明确知道该列表是静态,或者不必关注其顺序,可以选择忽略。**
**示例:**
~~~
<template>
<view>
<!-- array 中 item 的某个 property -->
<view v-for="(item,index) in objectArray" :key="item.id">
{{index +':'+ item.name}}
</view>
<!-- item 本身是一个唯一的字符串或者数字时,可以使用 item 本身 -->
<view v-for="(item,index) in stringArray" :key="item">
{{index +':'+ item}}
</view>
</view>
</template>
<script>
export default {
data () {
return {
objectArray:[{
id:0,
name:'li ming'
},{
id:1,
name:'wang peng'
}],
stringArray:['a','b','c']
}
}
}
</script>
~~~
- 内容介绍
- EcmaScript基础
- 快速入门
- 常量与变量
- 字符串
- 函数的基本概念
- 条件判断
- 数组
- 循环
- while循环
- for循环
- 函数基础
- 对象
- 对象的方法
- 函数
- 变量作用域
- 箭头函数
- 闭包
- 高阶函数
- map/reduce
- filter
- sort
- Promise
- 基本对象
- Arguments 对象
- 剩余参数
- Map和Set
- Json基础
- RegExp
- Date
- async
- callback
- promise基础
- promise-api
- promise链
- async-await
- 项目实践
- 标签系统
- 远程API请求
- 面向对象编程
- 创建对象
- 原型继承
- 项目实践
- Classes
- 构造函数
- extends
- static
- 项目实践
- 模块
- import
- export
- 项目实践
- 第三方扩展库
- immutable
- Vue快速入门
- 理解MVVM
- Vue中的MVVM模型
- Webpack+Vue快速入门
- 模板语法
- 计算属性和侦听器
- Class 与 Style 绑定
- 条件渲染
- 列表渲染
- 事件处理
- 表单输入绑定
- 组件基础
- 组件注册
- Prop
- 自定义事件
- 插槽
- 混入
- 过滤器
- 项目实践
- 标签编辑
- 移动客户端开发
- uni-app基础
- 快速入门程序
- 单页程序
- 底部Tab导航
- Vue语法基础
- 模版语法
- 计算属性与侦听器
- Class与Style绑定
- 样式与布局
- Box模型
- Flex布局
- 内置指令
- 基本指令
- v-model与表单
- 条件渲染指令
- 列表渲染指令v-for
- 事件与自定义属性
- 生命周期
- 项目实践
- 学生实验
- 贝店商品列表
- 加载更多数据
- 详情页面
- 自定义组件
- 内置组件
- 表单组件
- 技术专题
- 状态管理vuex
- Flyio
- Mockjs
- SCSS
- 条件编译
- 常用功能实现
- 上拉加载更多数据
- 数据加载综合案例
- Teaset UI组件库
- Teaset设计
- Teaset使用基础
- ts-tag
- ts-badge
- ts-button
- ta-banner
- ts-list
- ts-icon
- ts-load-more
- ts-segmented-control
- 代码模版
- 项目实践
- 标签组件
- 失物招领客户端原型
- 发布页面
- 检索页面
- 详情页面
- 服务端开发技术
- 服务端开发环境配置
- Koajs快速入门
- 快速入门
- 常用Koa中间件介绍
- 文件上传
- RestfulApi
- 一个复杂的RESTful例子
- 使用Mockjs生成模拟数据
- Thinkjs快速入门
- MVC模式
- Thinkjs介绍
- 快速入门
- RESTful服务
- RBAC案例
- 关联模型
- 应用开发框架
- 服务端开发
- PC端管理界面开发
- 移动端开发
- 项目实践
- 失物招领项目
- 移动客户端UI设计
- 服务端设计
- 数据库设计
- Event(事件)
- 客户端设计
- 事件列表页面
- 发布页面
- 事件详情页面
- API设计
- image
- event
- 微信公众号开发
- ui设计规范