微信小程序wx:for循环的实例详解


Posted in Javascript onOctober 07, 2018

列表渲染

wx:for

在组件上使用 wx:for 控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。
默认数组的当前项的下标变量名默认为 index,数组当前项的变量名默认为 item。

<view wx:for="{{array}}">
 {{index}}: {{item.message}}
</view>

Page({
 data: {
  array: [{
   message: 'foo',
  }, {
   message: 'bar'
  }]
 }
})

使用 wx:for-item 可以指定数组当前元素的变量名,

使用 wx:for-index 可以指定数组当前下标的变量名:

<view wx:for="{{array}}" wx:for-index="idx" wx:for-item="itemName">
 {{idx}}: {{itemName.message}}
</view>

wx:for 也可以嵌套,下边是一个九九乘法表

<view wx:for="{{[1, 2, 3, 4, 5, 6, 7, 8, 9]}}" wx:for-item="i">
 <view wx:for="{{[1, 2, 3, 4, 5, 6, 7, 8, 9]}}" wx:for-item="j">
  <view wx:if="{{i <= j}}">
   {{i}} * {{j}} = {{i * j}}
  </view>
 </view>
</view>

block wx:for

类似 block wx:if,也可以将 wx:for 用在标签上,以渲染一个包含多节点的结构块。例如:

<block wx:for="{{[1, 2, 3]}}">
 <view> {{index}}: </view>
 <view> {{item}} </view>
</block>

wx:key

如果列表中项目的位置会动态改变或者有新的项目添加到列表中,并且希望列表中的项目保持自己的特征和状态(如  中的输入内容, 的选中状态),需要使用 wx:key 来指定列表中项目的唯一的标识符。

wx:key 的值以两种形式提供

字符串,代表在 for 循环的 array 中 item 的某个 property,该 property 的值需要是列表中唯一的字符串或数字,且不能动态改变。保留关键字 *this 代表在 for 循环中的 item 本身,这种表示需要 item 本身是一个唯一的字符串或者数字,如:当数据改变触发渲染层重新渲染的时候,会校正带有 key 的组件,框架会确保他们被重新排序,而不是重新创建,以确保使组件保持自身的状态,并且提高列表渲染时的效率。

如不提供 wx:key,会报一个 warning, 如果明确知道该列表是静态,或者不必关注其顺序,可以选择忽略。
示例代码:

<switch wx:for="{{objectArray}}" wx:key="unique" style="display: block;"> {{item.id}} </switch>
<button bindtap="switch"> Switch </button>
<button bindtap="addToFront"> Add to the front </button>
<switch wx:for="{{numberArray}}" wx:key="*this" style="display: block;"> {{item}} </switch>
<button bindtap="addNumberToFront"> Add to the front </button>

Page({
 data: {
  objectArray: [
   {id: 5, unique: 'unique_5'},
   {id: 4, unique: 'unique_4'},
   {id: 3, unique: 'unique_3'},
   {id: 2, unique: 'unique_2'},
   {id: 1, unique: 'unique_1'},
   {id: 0, unique: 'unique_0'},
  ],
  numberArray: [1, 2, 3, 4]
 },
 switch: function(e) {
  const length = this.data.objectArray.length
  for (let i = 0; i < length; ++i) {
   const x = Math.floor(Math.random() * length)
   const y = Math.floor(Math.random() * length)
   const temp = this.data.objectArray[x]
   this.data.objectArray[x] = this.data.objectArray[y]
   this.data.objectArray[y] = temp
  }
  this.setData({
   objectArray: this.data.objectArray
  })
 },
 addToFront: function(e) {
  const length = this.data.objectArray.length
  this.data.objectArray = [{id: length, unique: 'unique_' + length}].concat(this.data.objectArray)
  this.setData({
   objectArray: this.data.objectArray
  })
 },
 addNumberToFront: function(e){
  this.data.numberArray = [ this.data.numberArray.length + 1 ].concat(this.data.numberArray)
  this.setData({
   numberArray: this.data.numberArray
  })
 }
})

注意:

当 wx:for 的值为字符串时,会将字符串解析成字符串数组

<view wx:for="array">
 {{item}}
</view>

等同于

<view wx:for="{{['a','r','r','a','y']}}">
 {{item}}
</view>

注意: 花括号和引号之间如果有空格,将最终被解析成为字符串

<view wx:for="{{[1,2,3]}} ">
 {{item}}
</view>

等同于

<view wx:for="{{[1,2,3] + ' '}}" >
 {{item}}
</view>

总结

以上所述是小编给大家介绍的微信小程序wx:for循环,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
js日期范围初始化得到前一个月日期的方法
May 05 Javascript
基于JavaScript代码实现随机漂浮图片广告
Jan 05 Javascript
jQuery简单操作cookie的插件实例
Jan 13 Javascript
angularjs表格ng-table使用备忘录
Mar 09 Javascript
第三篇Bootstrap网格基础
Jun 21 Javascript
js-FCC算法-No repeats please字符串的全排列(详解)
May 02 Javascript
jquery中done和then的区别(详解)
Dec 19 jQuery
vue中Element-ui 输入银行账号每四位加一个空格的实现代码
Sep 14 Javascript
SSM+layUI 根据登录信息显示不同的页面方法
Sep 20 Javascript
webpack优化之代码分割与公共代码提取详解
Nov 22 Javascript
Vue 中使用 typescript的方法详解
Feb 17 Javascript
JS将指定的某个字符全部转换为其他字符实例代码
Oct 13 Javascript
vue同步父子组件和异步父子组件的生命周期顺序问题
Oct 07 #Javascript
Vue面试题及Vue知识点整理
Oct 07 #Javascript
解决vue无法设置滚动位置的问题
Oct 07 #Javascript
cdn模式下vue的基本用法详解
Oct 07 #Javascript
vue实现添加与删除图书功能
Oct 07 #Javascript
JavaScript检查数据中是否存在相同的元素(两种方法)
Oct 07 #Javascript
JS函数内部属性之arguments和this实例解析
Oct 07 #Javascript
You might like
php实例分享之html转为rtf格式
2014/06/02 PHP
PHP5全版本绕过open_basedir读文件脚本漏洞详细介绍
2015/01/20 PHP
php中二分法查找算法实例分析
2016/09/22 PHP
PHP会话操作之cookie用法分析
2016/09/28 PHP
在Thinkphp中使用ajax实现无刷新分页的方法
2016/10/25 PHP
Linux平台PHP5.4设置FPM线程数量的方法
2016/11/09 PHP
PHP数组相加操作及与array_merge的区别浅析
2016/11/26 PHP
基于jquery的一个简单的脚本验证插件
2010/04/05 Javascript
JS不能跨域借助jquery获取IP地址的方法
2014/08/20 Javascript
node.js中的favicon.ico请求问题处理
2014/12/15 Javascript
jQuery中element选择器用法实例
2014/12/29 Javascript
Javascript实现商品秒杀倒计时(时间与服务器时间同步)
2015/09/16 Javascript
使用堆实现Top K算法(JS实现)
2015/12/25 Javascript
WordPress 单页面上一页下一页的实现方法【附代码】
2016/03/10 Javascript
js小数计算小数点后显示多位小数的实现方法
2016/05/30 Javascript
AngularJS 服务详细讲解及示例代码
2016/08/17 Javascript
js实现html table 行,列锁定的简单实例
2016/10/13 Javascript
bootstrap轮播模板使用方法详解
2017/11/17 Javascript
Vue表单类的父子组件数据传递示例
2018/05/03 Javascript
如何使用VuePress搭建一个类型element ui文档
2019/02/14 Javascript
layUI使用layer.open,在content打开数据表格,获取值并返回的方法
2019/09/26 Javascript
vue简单封装axios插件和接口的统一管理操作示例
2020/02/02 Javascript
JS获取表格视图所选行号的ids过程解析
2020/02/21 Javascript
JS实现炫酷轮播图
2020/11/15 Javascript
k8s node节点重新加入master集群的实现
2021/02/22 Javascript
python刷投票的脚本实现代码
2014/11/08 Python
python获取图片颜色信息的方法
2015/03/18 Python
Python实现的多线程同步与互斥锁功能示例
2017/11/30 Python
解决tensorflow测试模型时NotFoundError错误的问题
2018/07/27 Python
python读取csv和txt数据转换成向量的实例
2019/02/12 Python
Python vtk读取并显示dicom文件示例
2020/01/13 Python
python 实现批量图片识别并翻译
2020/11/02 Python
美国网上鞋城:Shoeline.com
2016/11/17 全球购物
工作说明书范文
2014/05/07 职场文书
爱心捐款活动总结
2015/05/09 职场文书
分析设计模式之模板方法Java实现
2021/06/23 Java/Android