前言 在微信小程序中,包含了很多指令,有wx:for、wx:if等。其中,wx:if是用来判断某个条件是否成立,如果返回值为true,则渲染这个元素,否则不渲染;还可以使用wx:if显示或隐藏一个元素

一、wx:if 在框架中,使用 wx:if="" 来判断是否需要渲染该代码块,也可以用 wx:elif 和 wx:else 来添加一个 else 块。

1 2 3 view1 view2

<blockwx:if="{{true}}">view1view2

三、wx:if vs hidden wx:if 也是惰性的,如果在初始渲染条件为 false,框架什么也不做,在条件第一次变成真的时候才开始局部渲染。

hidden 就简单的多,组件始终会被渲染,只是简单的控制显示与隐藏 性能分析:wx:if 有更高的切换消耗而 hidden 有更高的初始渲染消耗。

因此,如果需要频繁切换的情景下,用 hidden 更好,如果在运行时条件不大可能改变则 wx:if 较好

总结 如果需要频繁切换状态,用 hidden,否则用 wx:if。也就是说,wx:if 能够实时创建渲染组件或销毁组件,而且当他为真时才会创建,初始为假时什么也不做,由真变为假时则进行销毁。所以频繁切换他是一个比较耗性能举动。而 hidden 则代表页面初始渲染时就会把该组件渲染在页面上,值的真假只是控制其显示隐藏罢了。页面不销毁,则该组件也不会被销毁。明白了这一点,你会发现,从我们开发者的角度来说,灵活使用这两个条件判断会事半功倍。