微信小程序day01_13之小程序视图层列表渲染

本文深入讲解小程序中列表渲染的实现方式,包括wx:for的基本用法、注意事项及如何使用wx:for-item和wx:for-index自定义变量名。同时,探讨了使用view和block标签在渲染列表时的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

列表渲染

官网文档
https://developers.weixin.qq.com/miniprogram/dev/framework/view/wxml/list.html

wx:for
在组件上使用 wx:for 控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。

默认数组的当前项的下标变量名默认为 index,数组当前项的变量名默认为 item
代码示例:
在js中定义如下的数组

Page({
  /**
   * 页面的初始数据    
   */
  data: {
    users: [
      {name: "jack"},
      {name: "rose"},
      {name: "lily"}
    ]
  }
 })

在页面中引用如下

<view class='container'>
  <view wx:for="{{users}}">
      下标: {{index}} , 姓名 : {{item.name}}
  </view>
</view>

最终显示效果如下, 成功进行了数组的遍历

  • 使用 wx:for-item 可以指定数组当前元素的变量名,即可以改变默认的当前元素item,
  • 使用 wx:for-index 可以指定数组当前下标的变量名,可以改变默认的下标index:
    代码示例
 <view wx:for="{{users}}" wx:for-index="idx" wx:for-item="itemName">
      下标: {{idx}} , 姓名 : {{itemName.name}}
  </view>

显示效果如下, 同样进行了遍历

block wx:for
以渲染一个包含多节点的结构块
代码示例

<view class='container'>
  <view wx:for="{{users}}">
      下标: {{index}} , 姓名 : {{item.name}}
  </view>

  <block wx:for="{{users}}">
      下标: {{index}} , 姓名 : {{item.name}}
  </block>

</view>

效果如图所示, 用block标签的 没有换行, 使用view标签的换行了.

关于列表渲染的注意事项

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

例如代码如下:

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

会等同于如下

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

页面中实际渲染如下:

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

例如代码如下

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

等同于如下的代码

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

实际渲染如下, 会有空格隔开.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值