vuetify2中,Button-Group组件的使用

Button-Group组件的基础属性

multiple: 带有 multiple 属性将允许用户选中多个值并以数组的形式返回。
mandatory: 带有 mandatory 属性 将总是有一个(被选中的)值。

组件默认绑定一个 change事件,监听组件每次变化,返回选中值的数组。单个按钮绑定value属性,则监听返回value值数组。

实现功能

1.在此基础上需要实现一个功能,点击不同的按钮或按钮组,渲染不同的数据。
2.点击第一个按钮(全部),取消后面所有按钮选中状态。
3.点击多选后面的按钮,取消第一个按钮(全部)的选中状态。

changeHandler (value) {
					// 获取返回数组中特殊项。
                    var spItem = value.find(item => item === '全部')
                    // 判断数组是否存在特殊项
                    if (spItem) {
                        // 判断数组的第一个是否为特殊项,且长度大于1时
                        if (value[0] === spItem && value.length > 1) {
                            value = value.filter(item => item !== spItem)
                            // 重新赋值,渲染组件按钮的选中状态
                            this.currentYear = value
                            // 请求参数的值,与选中按钮返回的值一致
                            this.searchConditionObj.nf.selected = value
                            // 发起请求
                            this.getChartData()
                        }
                        // 判断数组的最后一个是否为特殊项,且长度大于1时
                        if (value[value.length - 1] === spItem && value.length > 1) {
                        	// 当再次点击特殊项,取消其他选中项状态,只留特殊项
                            value = spItem
                            this.currentYear = value
                            this.searchConditionObj.nf.selected = value
                            this.getChartData()
                        }
                    } else {
                    	// 组件按钮选中项的返回值没有特殊项,正常赋值
                        this.searchConditionObj.nf.selected = value
                        this.getChartData()
                    }
                },
  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值