位置: IT常识 - 正文

【微信小程序】条件渲染和列表渲染(微信小程序开发)

编辑:rootadmin
【微信小程序】条件渲染和列表渲染

推荐整理分享【微信小程序】条件渲染和列表渲染(微信小程序开发),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:微信小程序在哪里找?,微信小程序在哪里找?,微信小程序制作,微信小程序开发平台,微信小程序店铺怎么开,微信小程序怎么制作自己的小程序,微信小程序店铺怎么开,微信小程序怎么制作自己的小程序,内容如对您有帮助,希望把文章链接给更多的朋友!

🍒🍒 观众老爷们好啊,牛牛又更新了,上文我们详细了解了微信小程序中的事件绑定,那么今天我们就来讲讲WXML语法中的列表渲染和条件渲染,它俩也是非常重要的知识点,赶紧学起来吧。 🍒🍒 不过首先,我们想来补充一下数据传参的知识点以及常用的input事件用法。

文章目录一,事件传参二,input事件使用三,条件渲染四,列表渲染一,事件传参

首先我们需要知道,微信小程序中事件处理函数的传参,并不能直接在绑定时间的同时做,也就是说以下这样操作。

<view bindtap="tapName(2)">错误</view>

是不行的,如此编译器只会将整个tapName(2)识别成事件处理函数的名字。

如果想要传参,需要为组件提供自定义属性,格式如此——data-*,*代表该自定义属性的名字。

具体实现如下:

<view bindtap="tapName" data-info="{{2}}"></view>

然后我们在事件处理函数中,只需要通过event.target.dataset.info即可获取该传入的参数。

还记得之前说过事件对象event中的target属性吗,里面就是记录触发事件组件的一些属性值,上面用到的原理就是这里。

小tip: 需要注意的是,对于已经确认为数值的参数,我们采用Mustache语法,也就双括号括住参数,而如果我们只是用双引号包围,如下:

<view bindtap="tapName" data-info="2"></view>

解析到的data-info的值将会是一个字符串,"2"。

二,input事件使用

input事件在小程序开发中是比较常用的,具体表述就是为文本框绑定事件,当内容发生变化触发。

如下设置:

<input type="text" bidninput="changetext"></input>

一般我们使用该事件时,需要在对应的事件处理函数获取到input文本框的输入值,可以如下进行操作:

changetext(e){console.log(e.detail.value)}

e.detail.value就是对应着变化后的最新值。

三,条件渲染

条件渲染其实就相当于在WXML中的if语句,利用条件判断是否渲染某一个或一部分的组件。

【微信小程序】条件渲染和列表渲染(微信小程序开发)

语法为wx:if="{{condition}}",通过判断里面的condition增加来渲染,如果为true,则渲染组件。

除了if,还有与之配套的elif和else。

<view wx:if="{{type==1}}">男</view><view wx:if="{{type==2}}">女</view><view>不详</view>

当type为1,只有第一个view组件被渲染,当type为2,只有第二个组件被渲染,如果均不满足,则只渲染第三个组件。

其实条件渲染除了if还有hidden可以做到。

语法为hidden= "{{condition}}",hidden为组件属性,当里面condition条件值为false,组件不隐藏,为true,组件隐藏。

说到这里大家可能发觉,我们还不知道如何一次性控制多组件展示隐藏。

微信小程序中有一个<block>,它并不是组件,只是有包裹性质的容器,即使写进wxml,也不会被渲染(调试器也不会看到它的存在),我们可以利用它来实现。

<block wx:if="{{info==1}}"><view>a</view><view>b</view><view>c</view></block>

if和hidden对比:

从本质上,

if是动态创建和移除组件而hidden是通过改变样式,设置display为none或block实现的

从使用上,当我们需要频繁的切换时,建议使用hidden,而当控制条件复杂时,特别需要用到elseif效果的时候,建议使用if。

四,列表渲染

列表渲染其实从理解上,就是在wxml语法中的for语句,实现循环。

语法为wx:for="{{array}}",根据指定数组,循环渲染复杂的组件,注意,双括号中的是数组哦。使用中,我们一般同时还有给其设定唯一key值,语法为wx:key。

比如我们的数组如下:

user:[{id:1, name:"apple"},{id:2, name:"add"},{id:3, name:"abandon"}]

这样我们可以设置wx:key="id",当我们调用里面的name,循环会根据key遍历,调用时key为何值,调用就是哪一个name值。

<view wx:for="{{user}}" wx:key="id">{{name}}<view>

需要注意的是,设置key不需要使用{{}}

如果数组没有这种id属性,我们可以直接设定key为index,如wx:key="index",也是可以循环遍历数组。

好啦,本次小程序的文章到这里就结束啦,如果对您有帮助的话,可以继续关注牛牛后续的文章呀,您的支持是我们创作的最大动力!

🍒牛牛最近发现一款刷题神器,各大互联网大厂的面试真题,还有超大面试题库。 🍒里面还有很多大佬的面经,赶紧卷起来!! 点击直接访问

债见~~

本文链接地址:https://www.jiuchutong.com/zhishi/300392.html 转载请保留说明!

上一篇:DEFORMABLE DETR详解(deformable detr代码)

下一篇:【react从入门到精通】初识React(react 入门教程)

  • vivox70pro蓝牙耳机怎么连接手机(vivox7蓝牙耳机)

    vivox70pro蓝牙耳机怎么连接手机(vivox7蓝牙耳机)

  • 电话被对方拉黑还有什么方法可以联系呢(电话被对方拉黑了怎么破解)

    电话被对方拉黑还有什么方法可以联系呢(电话被对方拉黑了怎么破解)

  • 华为曲面屏一摔就碎(华为曲面屏摔碎在哪里修)

    华为曲面屏一摔就碎(华为曲面屏摔碎在哪里修)

  • 微信按日期怎么查与谁聊天(微信怎么选择日期)

    微信按日期怎么查与谁聊天(微信怎么选择日期)

  • 苹果x怎样截屏(苹果怎样截屏)

    苹果x怎样截屏(苹果怎样截屏)

  • 三星s20刷新率(三星s20刷新率工具)

    三星s20刷新率(三星s20刷新率工具)

  • ipad钉钉闪退是什么原因(平板钉钉闪退)

    ipad钉钉闪退是什么原因(平板钉钉闪退)

  • 1g和1gb哪个大(1g跟1gb哪个大)

    1g和1gb哪个大(1g跟1gb哪个大)

  • 您已设置呼叫限制什么意思(您已设置呼叫限制怎么取消小米)

    您已设置呼叫限制什么意思(您已设置呼叫限制怎么取消小米)

  • http是一种主要用于加密的协议吗

    http是一种主要用于加密的协议吗

  • b站青少年模式弹窗怎么关(b站青少年模式密码重置需要多久)

    b站青少年模式弹窗怎么关(b站青少年模式密码重置需要多久)

  • 荣耀20怎么设置返回键(荣耀20怎么设置动态壁纸)

    荣耀20怎么设置返回键(荣耀20怎么设置动态壁纸)

  • 虚拟内存设置多少合适(虚拟内存设置多少好)

    虚拟内存设置多少合适(虚拟内存设置多少好)

  • QQ浏览器中怎样编辑word文档(qq浏览器中怎样删除空白页)

    QQ浏览器中怎样编辑word文档(qq浏览器中怎样删除空白页)

  • 苹果蓝牙耳机不亮灯了怎么回事(苹果蓝牙耳机不是正品可以配对吗)

    苹果蓝牙耳机不亮灯了怎么回事(苹果蓝牙耳机不是正品可以配对吗)

  • vivoy5s像素多少(vivo y5像素)

    vivoy5s像素多少(vivo y5像素)

  • word表格布局在哪里(word表格布局选项卡在哪里)

    word表格布局在哪里(word表格布局选项卡在哪里)

  • 华为的充电器叫什么(华为的充电器叫什么头)

    华为的充电器叫什么(华为的充电器叫什么头)

  • 苹果11支持反向无线充电吗(苹果11支持反向充电功能吗)

    苹果11支持反向无线充电吗(苹果11支持反向充电功能吗)

  • 如何做滴滴司机(如何成为滴滴网约车司机)

    如何做滴滴司机(如何成为滴滴网约车司机)

  • 计算机上的ce键代表着什么(计算机上的ce键有什么用)

    计算机上的ce键代表着什么(计算机上的ce键有什么用)

  • kindle云端在哪(kindle云端阅读器)

    kindle云端在哪(kindle云端阅读器)

  • 华为荣耀20有红外线吗(华为荣耀20红外线功能怎么开)

    华为荣耀20有红外线吗(华为荣耀20红外线功能怎么开)

  • word怎么做图表(word怎么做图表分析)

    word怎么做图表(word怎么做图表分析)

  • Vue 通过style属性、class属性来动态修改CSS样式(vue style import)

    Vue 通过style属性、class属性来动态修改CSS样式(vue style import)

  • 北京增值税发票勾选认证平台
  • 个人开发选项
  • 代扣个税怎么做凭证
  • 税收保全措施有金银首饰吗
  • 经营范围没广告怎么办
  • 个体户一定要自己经营吗
  • 短期借款可以按币种设置明细核算
  • 房屋租赁收入怎么做账
  • 债券置换债务
  • 原始凭证怎么做账
  • 固定资产没收到发票收到实物入账有什么风险
  • 房地产限购过程是什么
  • 车辆保险赔款怎么入账
  • 房屋所有权变更登记证书
  • 公司购买固定资产需要交印花税吗
  • 固定资产预计净残值怎么做账
  • 存货的进项税要计入成本吗
  • 旅游服务费计入什么费用
  • 花椒油的税率
  • 版权使用费属于什么税目
  • 股份利润怎么分
  • 普票红冲对方已入账发票拿不回来
  • 控股子公司是
  • Win11 Build 10.0.22000.51 预览版ISO镜像下载汇总(苹果M1也可用)
  • 我们无法创建新的分区,也找不到现有的分区 贴吧
  • 销售商品分期收款,减免一部分货款怎么做账
  • 低值易耗品处理的目的
  • 一般纳税人购进农产品如何抵扣进项税额
  • php字符串型数据的定义方式
  • 不动产在建工程领用原材料的分录
  • win10任务栏搜索如何关闭
  • 运输发票符合什么要求
  • 什么手机最薄最有手感
  • php中defined什么意思
  • 入固定资产含税吗
  • 收回已核销的坏账分录
  • php ssl
  • cgtrader模型
  • 关于php文件的自动播放
  • 小企业会计准则适用于哪些企业
  • Ubuntu18.04安装cuda10.2
  • vue3环境搭建
  • 数据库如何迁移数据库表
  • 出租房屋收取跨年度的预收租金收入
  • 社保缴费基数是怎么确定的
  • 补交上年度的企业所得税税款计入什么科目
  • 即征即退进项税怎么划分合算
  • java8 (jdk 1.8) 新特性——Lambda
  • 进口增值税是什么意思
  • sqlserver 删除数据
  • 库存暂估入账的会计分录
  • 交易费用计入何种科目
  • 发票开出来对方不走账会怎么样?
  • 小规模纳税人交通运输服务税率
  • 现金折扣定价案例
  • 项目毛利润怎么算
  • 明细账的作用
  • 货币资金核算制度是什么
  • mysql必知必会读书心得
  • 如何修改sqlserver中sa用户的密码
  • sql存储过程实例详解
  • 将u盘制作成u启动u盘启动盘
  • ubuntu系统怎么更新
  • 微软平板电脑surface pro2参数
  • 在windows 7
  • linux 常见
  • linux 垃圾
  • win8.1 应用商店是不是不能用了
  • win7怎样解除无线连接限制
  • win7系统网络连接禁用怎么开启
  • win10内置管理员账户禁用
  • 水下摄影技巧
  • ExtJS4 组件化编程,动态加载,面向对象,Direct
  • python咋写
  • 浅谈关于混合模式教学的看法
  • Forward Render VS Deferred Rendering
  • 基于python的应用
  • python随机数random.choice
  • 广东税务怎么查社保缴费明细
  • 武汉二手房交易信息
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设