uview select封装单选和多选

本文介绍了如何在uview中封装一个支持单选和多选的组件。通过添加字段来判断多选状态,并在changeItem()方法中处理已选择项的增删,利用indexOf()判断值是否存在。同时展示了相关的代码示例,涉及到数组的join()和splice()方法的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

uview是没有多选的,根据业务需求就自己封装了一个组件

一般多选的话是要加字段,根据字段判断,这个思路值得记录下

<template>
	<view class="slot-v">
		<!-- 单选 -->

		<u-input v-model="inputValue" type="select" @click="selectShow = true" :placeholder="placeholder" />
	
		<!-- 多选 -->
		<u-popup title="请选择角色" mode="bottom" v-model="selectShow" :mask-close-able="false">
			<view class="slot-content" style="background-color: #FFFFFF;">
				<view class="slot_title">
					<view @click="handleCancel" style="padding: 0 24rpx;">取消</view>
					<view @click="handleOK" style="color: #0181ff;padding: 0 24rpx;">确认</view>
				</view>
				<scroll-view scroll-y="true" style="height: 400rpx;">
					<view v-for="(item,index) in selectList" :key="index" @click="changeItem(item)" :class="[multiple?'':'multiple',selectedRoles.indexOf(item.value)>-1?'selected':'']"
						class="safe-area-inset-bottom itemstyle">
						<text>{
  
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值