转自:https://idig8.com/2018/08/09/xiaochengxu-chuji-14/

列表的渲染,不管是任何语言都有列表这个概念。源码:https://github.com/limingios/wxProgram.git 中的No.8

小程序的列表的渲染

  1. for 循环

     

  2.  

  3. 官方的阐述

https://developers.weixin.qq.com/miniprogram/dev/framework/view/wxml/list.html

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

  1. 演示列表
    >* wx:for
    在组件上使用 wx:for 控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。
    >* block wx:for
    类似 block wx:if,也可以将 wx:for 用在标签上,以渲染一个包含以渲染一个包含多节点的结构块。

listFor.wxml

<!listFor.wxml-->
<view class="container">
  <view wx:for="{{users}}" wx:key="userInfoListId1">
    下标:{{index}},内容:{{item.name}}
  </view>
  <!---index别名的方式,item别名的方式-->
  <view wx:for="{{users}}"wx:for-index="idx" wx:for-item="itemName"  wx:key="userInfoListId2">
    下标:{{idx}},内容:{{itemName.name}}
  </view>
<!---block 是一行下来的,不会自动换行-->
   <block wx:for="{{users}}"wx:for-index="idx" wx:for-item="itemName"  wx:key="userInfoListId3">
    下标:{{idx}},内容:{{itemName.name}}
  </block>

<!--字符串,自动变成数组-->
  <view wx:for="微信公众号:编程坑太多">
     {{item}}
  </view>
   <!---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>
</view>

listFor.js

//listFor.js
//获取应用实例
const app = getApp()

Page({
  data: {
    users: [{
        name: "公众名称"
      },
      {
        name: "编程坑太多"
      },{
        name: "公众号"
      },{
        name: "idig88"
      }

    ]

  }

})

在实际开发过程中遇到 warning: Now you can provide attr “wx:key” for a “wx:for” to improve performance.
如果明确知道该列表是静态,或者不必关注其顺序,可以选择忽略。
解决方案还是有的 wx:key=”几个名字加进去”

PS:下节详细解释下wx:key 的重要性。

posted on 2019-01-16 07:00  Sharpest  阅读(169)  评论(0编辑  收藏  举报