微信小程序如何自定义单选和多选

实现单选

实现效果:点击显示单选状态,每次仅能点击一个元素。

af963008e74742d785579599ceeb469c.png

实现方式:

wxml: 

<view wx:for="{{item_list}}" data-info="{{index}}" class="{{menu_index===index?'choose':'no_choose'}}" bind:tap="changeColor">{{item}}</view>

 item_list是单选的元素,class定义了选中和未选中的显示形式,changeColor更新点击元素。

 .wxss 

.choose{color: red;background-color: white;font-weight: bold;
}
.no-choose{color:black
}

定义选中和未选中的显示样式。

.js 

data:{item_list:['牛肉粉','小吃','加料','饮料']
},  
changeColor(e){this.setData({menu_index: e.currentTarget.dataset.info,});}

changeColor实时更新点击元素信息。 

实现多选

实现效果:点击多个元素均能显示点击状态。

a41716257c8a465f918485507bbedad2.png

再次点击可取消选择:

02a825adc4a64f8897ddbbb0cc78c034.png

.wxml

<view wx:for="{{item_list}}" class="{{menu_index[index]==index?'choose':'no_choose'}}" data-index="{{index}}" bind:tap="changeColor">{{item}}</view>

 item_list是单选的元素,class定义了选中和未选中的显示形式,changeColor更新点击元素。

.wxss 

.choose{color: red;background-color: white;font-weight: bold;
}
.no-choose{color:black
}

定义选中和未选中的显示样式。 

 .js 

data:{item_list:['牛肉粉','小吃','加料','饮料']
},  
changeColor(e){var m_index = this.data.menu_indexvar index = e.currentTarget.dataset.indexvar m = "menu_index."+ e.currentTarget.dataset.indexif(m_index[index]==index){this.setData({[m]: -1})}else{this.setData({[m]: e.currentTarget.dataset.index})}
}

changeColor实时更新点击元素信息,将已点击元素保存包m_index,当元素处于选中状态m_index[index]的值等于传回的index,当元素再次被点击,取消点击状态时, m_index[index]=-1。

更多内容欢迎关注。

有用的话欢迎赞赏。

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/645891.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

实现低失调、低噪声的四路运算放大器MC33079DR2G与解决方案

MC33079DR2G是一款电源管理芯片&#xff0c;是优质单片运算放大器&#xff0c;采用具有创新高性能概念的双极技术&#xff0c;适用于优质音频和数据信号处理应用。结合了高频率 PNP 输入晶体管的使用&#xff0c;可产生具有低输入电压噪声和高增益带宽产品和摆率的放大器。所有…

MySQL的奇妙冒险:与数据跳华尔兹

引言&#xff1a;跳进MySQL的舞池 欢迎来到MySQL的世界&#xff0c;这里充满了表格、查询和一些奇妙的数据舞步。作为世界上最受欢迎的开源关系型数据库之一&#xff0c;MySQL就像是一个永远不睡觉的数据守护者。现在&#xff0c;让我们一起踏上这段轻松却充满学问的旅程&…

每日Linux(一)——man和help命令

man和help 引子man&#xff08;manual&#xff09;helphelp和man的区别内建命令 vs 外部命令内建命令 (Built-in Commands):外部命令 (External Commands):如何判断是内建命令和外部命令 再学习 引子 为什么要从man和help开始学习&#xff1f;因为这两个命令可以大大提升学者的…

羊奶与牛奶,谁更好?

羊奶与牛奶&#xff0c;谁更好&#xff1f; 羊奶和牛奶是我们日常饮食中常见的乳制品&#xff0c;但究竟哪种更好呢&#xff1f;今天就让小编羊大师带大家一起来探讨一下&#xff0c;看看羊奶和牛奶在各方面的优势和劣势&#xff0c;帮助你作出更明智的选择。 让我们从营养价…

生成三维模型时,OSGB、PLY、OBJ、S3MB这几种格式分别有什么不同?

OSGB是一种二进制存储&#xff0c;带有嵌入式链接纹理数据的倾斜摄影三维数据格式。此类数据文件碎&#xff0c;数量多&#xff0c;高级别金字塔文件大&#xff0c;难以实现不同地域、不同部门之间的数据共享&#xff1b; OBJ是一种标准三维模型文件格式&#xff0c;一般包括三…

前端开发_JavaScript之WebAPI

WebAPI作用和分类 作用: 就是使用 JS 去操作 html 和浏览器 分类&#xff1a;DOM (文档对象模型)、BOM&#xff08;浏览器对象模型&#xff09; DOM DOM&#xff08;Document Object Model——文档对象模型&#xff09;是用来呈现以及与任意 HTML 或 XML文档交互的API DOM…

【8.ADC模数转换器】蓝桥杯嵌入式一周拿奖速成系列

系列文章目录 蓝桥杯嵌入式系列文章目录(更多此系列文章可见) ADC模数转换器 系列文章目录一、STM32CUBEMX配置二、项目代码1.main.c --> ADCProcess 总结 一、STM32CUBEMX配置 STM32CUBEMX PB15 -> ADC2_IN15 ; PB12-> ADC1_IN11ADCProcess 二、项目代码 1.main.c …

Kotlin 协程库v1.7.1的核心模块(kotlinx-coroutines-core)-- kotlinx.coroutines.flow篇

Flow 是一种异步数据流的表示&#xff0c;可以用于处理异步数据流的操作。 AbstractFlow&#xff08;ExperimentalCoroutinesApi&#xff09; 协程库中的一个抽象类&#xff0c;用于创建具有状态的 Flow 实现。它跟踪了用于上下文保留的所有属性&#xff0c;并在任何属性被违…

C语言通过IXMLHTTPRequest以get或post方式发送http请求获取服务器文本或xml数据

做过网页设计的人应该都知道ajax。 Ajax即Asynchronous Javascript And XML&#xff08;异步的JavaScript和XML&#xff09;。使用Ajax的最大优点&#xff0c;就是能在不更新整个页面的前提下维护数据。这使得Web应用程序更为迅捷地回应用户动作&#xff0c;并避免了在网络上发…

手撕重采样,考虑C的实现方式

一、参考文章&#xff1a; 重采样、上采样、下采样 - 知乎 (zhihu.com) 先直接给结论&#xff0c;正常重采样过程如下&#xff1a; 1、对于原采样率fs&#xff0c;需要重采样到fs1&#xff0c;一般fs和fs1都是整数哈&#xff0c;则先找fs和fs1的最小公倍数&#xff0c;设为m…

libjsoncpp 的编译和交叉编译

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…

开通商家转账到零钱技巧

商家转账到零钱是什么&#xff1f; 通过商家转账到零钱这个功能&#xff0c;如果我们系统需要对用户支付费用&#xff0c;比如发放佣金、提成、退款之类的&#xff0c;可以直接转账到用户的微信零钱。 【商家转账到零钱】是【企业付款到零钱】的升级版&#xff0c;2022年5月1…

H264解码原理详解

H.264的编码原理参考文章H.264的编码原理 解码原理 解码器负责将符合H.264码流规范的压缩视频流解码&#xff0c;并进行图像重建。 根据如下图所示的解码器流图&#xff0c;我们可以看出基本的解码流程如下&#xff1a;解码器从网络提取层中接收压缩的比特流&#xff0c;经过…

Mysql复习1--理论基础+操作实践--更新中

Mysql 索引索引的分类索引失效sql优化 删除数据库数据恢复 索引InnoDB引擎MyISAM引擎Memory引擎Btree索引支持支持支持hash索引不支持不支持支持R-tree索引不支持支持不支持Full-text索引5.6版本以后支持支持不支持 索引 解释说明: 索引指的是帮助mysql高效的获取数据的结构叫…

算法训练营Day48

#Java #动态规划 Feeling and experiences&#xff1a; 回文子串&#xff1a;力扣题目链接 给你一个字符串 s &#xff0c;请你统计并返回这个字符串中 回文子串 的数目。 回文字符串 是正着读和倒过来读一样的字符串。 子字符串 是字符串中的由连续字符组成的一个序列。 …

《Windows核心编程》若干知识点实战应用分享

目录 1、进程的虚拟内存分区与小于0x10000的小地址内存区 1.1、进程的虚拟内存分区 1.2、小于0x10000的小地址内存区 2、保存线程上下文的CONTEXT结构体 3、从汇编代码角度去理解多线程运行过程的典型实例 4、调用TerminateThread强制结束线程会导致线程中的资源没有释放…

WPF之鼠标快速移动进出Textbox导致联动的控件显示卡顿解决方案

如果你的应用在鼠标快速移动进出TextBox1时出现卡顿或者TextBox2的MessInfo显示失败&#xff0c;可能是由于频繁的UI线程更新引起的。你可以试试以下的一些解决方案&#xff1a; 使用防抖动/节流技术&#xff1a;防抖和节流是两种常用的控制函数调用频率的技术&#xff0c;防抖…

Redisson 分布式锁可重入的原理

目录 1. 使用 Redis 实现分布式锁存在的问题 2. Redisson 的分布式锁解决不可重入问题的原理 1. 使用 Redis 实现分布式锁存在的问题 不可重入&#xff1a;同一个线程无法两次 / 多次获取锁举例 method1 执行需要获取锁method2 执行也需要&#xff08;同一把&#xff09;锁如…

Python map函数

在Python编程中&#xff0c;map()函数是一个强大的工具&#xff0c;用于将函数应用于可迭代对象&#xff08;如列表、元组等&#xff09;的每个元素&#xff0c;然后返回一个新的可迭代对象&#xff0c;其中包含应用函数后的结果。本文将深入探讨map()函数的用法&#xff0c;提…

云计算项目五:部署数据库服务mysql |部署共享存储服务NFS | 配置网站服务

部署数据库服务mysql |部署共享存储服务NFS | 配置网站服务 案例1:配置逻辑卷步骤一:创建LV步骤二:格式化案例2:配置数据库服务器步骤一:安装软件MySQL服务软件(2台数据库服务器都要安装)步骤二:挂载lv设备步骤三:启动服务步骤四:管理员登录案例3:配置主从同步步骤一…