源码论坛公告:本站是一个交流学习建站资源的社区论坛,旨在交流学习源码脚本等资源技术,欢迎大家投稿发言! 【点击此处将锦尚放在桌面

源码论坛,商业源码下载,尽在锦尚中国商业源码论坛

 找回密码
 会员注册

QQ登录

只需一步,快速开始

查看: 3492|回复: 0
打印 上一主题 下一主题

[小程序开发] 十分钟搞定小程序的条件渲染

[复制链接]

3123

主题

3525

帖子

14万

金币

超级版主

Rank: 8Rank: 8

积分
287186
跳转到指定楼层
1#
发表于 2023-3-21 14:26:25 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

今天给大家带来了关于微信小程序条件渲染的相关知识,其中主要介绍了关于条件渲染的相关内容,所谓条件渲染就是判断是否要把代码渲染到展示页面上,下面一起来看一下,希望对大家有帮助。

1.wx:if实现条件渲染

在框架中,使用  来判断是否需要渲染该代码块:
  1. <view wx:if="{{condition}}">True<view>
复制代码

如果的值为true,就会在页面上渲染出view组件,否则将不会显示该组件。同时还可以结合和来使用,此时可以进行多条件的判断是否渲染该代码。
  1. <view wx:if="{{type===1}}">组件1</view><view wx:elif="{{type===2}}">组件2</view><view wx:else>组件3</view>
复制代码

下面做一个演示:在文件的data中定义一个type,同时在文件中定义三个view组件,根据type的值来决定是否渲染view组件。

下面做一个演示:在js文件的data中定义一个type,同时在wxml文件中定义三个view组件,根据type的值来决定是否渲染view组件。





此时,改变type的值就可以改变页面渲染的内容。

2.block结合wx:if使用

因为 wx:if 是一个控制属性,需要将它添加到一个标签上。如果要一次性判断多个组件标签,可以使用一个 <block/> 标签将多个组件包装起来,并在上边使用 wx:if 控制属性。
  1. <block wx:if="{{true}}">

  2.   <view> view1 </view>

  3.   <view> view2 </view></block>
复制代码

注意:不是一个组件,只是一个包裹性的容器,不会在页面上做任何渲染。

下面做一个演示:在<block>中包裹两个view组件,使用wx:if来决定是否需要渲染这两个组件。





此时在页面上渲染了两个view组件,block作为包裹性的容器并没有被渲染。

3.hiden实现条件渲染

在框架中,使用 hidden="" 来控制组件的显示与隐藏。与前面不同的是,hidden组件始终会被渲染,只是简单的控制显示与隐藏。
  1. <view hidden="{{false}}">当条件为true时则会隐藏该元素</view>
复制代码





可以在AppData中改变flag的值从而控制是否隐藏该view组件。

4. wx:if vs hidden
因为 wx:if 之中的模板也可能包含数据绑定,所以当 wx:if 的条件值切换时,框架有一个局部渲染的过程,因为它会确保条件块在切换时销毁或重新渲染。

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

相比之下,hidden 就简单的多,组件始终会被渲染,只是简单的控制显示与隐藏。

一般来说,wx:if 有更高的切换消耗而 hidden 有更高的初始渲染消耗。因此,如果需要频繁切换的情景下,用 hidden 更好,如果在运行时条件不大可能改变则 wx:if 较好。

好了,以上就是锦尚中国关于小程序的条件渲染的相关内容,感谢大家的支持与厚爱,需要更多的资源、素材、源码和教程请搜索本站!


分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享
您需要登录后才可以回帖 登录 | 会员注册

本版积分规则

锦尚中国源码论坛

聚合标签|锦尚中国,为中国网站设计添动力 ( 鲁ICP备09033200号 ) |网站地图

GMT+8, 2024-11-14 14:44 , Processed in 0.102379 second(s), 24 queries .

带宽由 锦尚数据 提供 专业的数据中心

© 锦尚中国源码论坛 52jscn Inc. 非法入侵必将受到法律制裁 法律顾问:IT法律网 & 褚福省律师 锦尚爱心 版权申诉 版权与免责声明