uni-app 获取单选 多选功能

该博客展示了如何在uni-app中实现单选和多选功能。通过`<checkbox-group>`组件,结合`v-for`指令动态渲染多选框,并实现了全选/全不选功能。`checkboxChange`、`changeCheckbox`和`allChoose`等方法处理了选中状态的改变。代码中定义了数据结构`checkboxData`和`checkedArr`来存储选项和选中状态。
摘要由CSDN通过智能技术生成

uni-app单选 多选功能

<view>
    <!-- 单个复选框 -->
    <checkbox-group class="block" @change="checkboxChange">
        <view class="cu-form-group">
            <view class="title">复选选操作(checkbox)</view>
            <checkbox :class="isChecked?'checked':''" :checked="isChecked?true:false" value="1"></checkbox>
        </view>
    </checkbox-group>
    
    <!-- 多个复选框,带全选 -->
    <view>
        <checkbox-group class="block" @change="changeCheckbox">
            <view v-for="item in checkboxData" :key="item.value">                
                <checkbox :value="String(item.value)" :checked="checkedArr.includes(String(item.value))" :class="{'checked':checkedArr.includes(String(item.value))}"></checkbox>
                <text>{{item.label}}</text>
            </view>
        </checkbox-group>
    </view>
    <view>
        <checkbox-group @change="allChoose">
            <label>
                <checkbox value="all" :class="{'checked':allChecked}" :checked="allChecked?true:false"></checkbox> 全选
            </label>
        </checkbox-group>
    </view>
</view>


export default {
    data() {
        return {
            isChecked:false,
            checkboxData:[
                {'value':0,'label':'选项一'},
                {'value':1,'label':'选项二'},
                {'value':2,'label':'选项三'},
                {'value':3,'label':'选项四'},
                {'value':4,'label':'选项五'},
                {'value':5,'label':'选项六'},
                {'value':6,'label':'选项七'},
                {'value':7,'label':'选项八'},
                {'value':8,'label':'选项九'},
                {'value':9,'label':'选项十'}
            ],
            checkedArr:[], //复选框选中的值
            allChecked:false //是否全选
        }
    },
    methods: {
        // 单个复选框事件
        checkboxChange(e) {
            let values = e.detail.value;
            if(values[0]==1){
                this.isChecked=true;
            }else{
                this.isChecked=false;
            }
        },
        // 多选复选框改变事件
        changeCheckbox(e){
            this.checkedArr = e.detail.value;
            // 如果选择的数组中有值,并且长度等于列表的长度,就是全选
            if(this.checkedArr.length>0 && this.checkedArr.length==this.checkboxData.length){
                this.allChecked=true;
            }else{
                this.allChecked=false;
            }
        },
        // 全选事件
        allChoose(e){
            let chooseItem = e.detail.value;
            // 全选
            if(chooseItem[0]=='all'){
                this.allChecked=true;
                for(let item of this.checkboxData){
                    let itemVal=String(item.value);
                    if(!this.checkedArr.includes(itemVal)){
                        this.checkedArr.push(itemVal);
                    }
                }                    
            }else{
                // 取消全选
                this.allChecked=false;
                this.checkedArr=[];
            }
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黑猫大人-魏盛楠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值