1、wx:for
在组件上使用 wx:for 控制属性绑定一个数组,即可使用数组中各项的数据重复渲染该组件。默认数组的当前
项的下标变量名默认为 index,数组当前项的变量名默认为 item
例子:
<!--WXML-->
<view wx:for="{{array}}">
<view>下标为:{{index}} 当前值:{{item}}</view>
</view>
// pages/test/test.js
Page({
data:{
array:[1, 2, 3, 4, 5, 6, 7, 8, 9]
},
})
结果:
使用 wx:for-item="" 可以指定数组当前元素的变量名,
使用 wx:for-index="" 可以指定数组当前下标的变量名。
例如:
<view wx:for="{{array}}" wx:for-index="myindex" wx:for-item="myitem">
自定义item和index名称为myitem和myindex。
2、wx:if
1、在框架中,使用 wx:if="" 来判断是否需要渲染该代码块。
2、也可以用 wx:elif 和 wx:else 来添加一个 else 块:
<view wx:if="{{length > 5}}"> 1 </view>
<view wx:elif="{{length > 2}}"> 2 </view>
<view wx:else> 3 </view>
3、block wx:if
因为 wx:if 是一个控制属性,需要将它添加到一个标签上。如果要一次性判断多个组件标签,可以使用一个
<block/> 标签将多个组件包装起来,并在上边使用 wx:if 控制属性。
<block wx:if="{{true}}">
<view> view1 </view>
<view> view2 </view>
</block>
注意: <block/> 并不是一个组件,它仅仅是一个包装元素,不会在页面中做任何渲染,只接受控制属性。
4、wx:if和hidden
因为 wx:if 之中的模板也可能包含数据绑定,所以当 wx:if 的条件值切换时,框架有一个局部渲染的过程,
因为它会确保条件块在切换时销毁或重新渲染。
同时 wx:if 也是惰性的,如果在初始渲染条件为 false,框架什么也不做,在条件第一次变成真的时候才开
始局部渲染。
相比之下,hidden 就简单的多,组件始终会被渲染,只是简单的控制显示与隐藏。
一般来说,wx:if 有更高的切换消耗而 hidden 有更高的初始渲染消耗。因此,如果需要频繁切换的情景下,
用 hidden 更好,如果在运行时条件不大可能改变则 wx:if 较好。
hidden=""的判断条件与wx:if=""相反。