当前位置: 首页 > 文档资料 > uView 开发文档 >

Checkbox 复选框

优质
小牛编辑
138浏览
2023-12-01

Checkbox 复选框 平台差异说明
AppH5微信小程序支付宝小程序百度小程序头条小程序QQ小程序

基本使用

  • 该组件无需强制搭配checkboxGroup组件使用(视情况而定),可以单个独立使用u-checkbox组件
  • 通过v-modelcheckbox绑定一个变量,这个绑定的变量是双向的(初始值只能是true或者false),也就是说,您可以无需监听checkbox或者checkboxGroup组件的change事件,也能知道哪个复选框 被勾选了
<template>
	<view class="">
		<u-checkbox-group @change="checkboxGroupChange">
			<u-checkbox 
				@change="checkboxChange" 
				v-model="item.checked" 
				v-for="(item, index) in list" :key="index" 
				:name="item.name"
			>{{item.name}}</u-checkbox>
		</u-checkbox-group>
		<u-button @click="checkedAll">全选</u-button>
	</view>
</template>

<script>
export default {
	data() {
		return {
			list: [
				{
					name: 'apple',
					checked: false,
					disabled: false
				},
				{
					name: 'banner',
					checked: false,
					disabled: false
				},
				{
					name: 'orange',
					checked: false,
					disabled: false
				}
			]
		};
	},
	methods: {
		// 选中某个复选框时,由checkbox时触发
		checkboxChange(e) {
			//console.log(e);
		},
		// 选中任一checkbox时,由checkbox-group触发
		checkboxGroupChange(e) {
			// console.log(e);
		},
		// 全选
		checkedAll() {
			this.list.map(val => {
				val.checked = true;
			})
		}
	}
};
</script>

禁用checkbox

设置disabledtrue,即可禁用某个组件,让用户无法点击,禁用分为两种状态,一是未勾选前禁用,这时只显示一个灰色的区域。二是已勾选后 再禁用,会有灰色的已勾选的图标,但此时依然是不可操作的。

<u-checkbox-group>
	<u-checkbox v-model="checked" :disabled="false">天涯</u-checkbox>
</u-checkbox-group>

自定义形状

可以通过设置shapesquare或者circle,将复选框设置为方形或者圆形

<u-checkbox-group>
	<u-checkbox v-model="checked" shape="circle">明月</u-checkbox>
</u-checkbox-group>

自定义颜色

此处所指的颜色,为checkbox选中时的背景颜色,参数为active-color

<u-checkbox-group>
	<u-checkbox v-model="checked" active-color="red">光影</u-checkbox>
</u-checkbox-group>

文本是否可点击

设置label-disabledfalse,点击文本时,无法操作checkbox

<u-checkbox-group>
	<u-checkbox v-model="checked" :label-disabled="false">剑舞</u-checkbox>
</u-checkbox-group>

API

Checkbox Props

注意:需要给checkbox组件通过v-model绑定一个布尔值,来初始化checkbox的状态,随后该值被双向绑定, 当用户勾选复选框时,该值在checkbox内部被修改为true,并反映到父组件,否则为false,换言之,您无需监听checkboxchange事件,也能 知道某一个checkbox是否被选中的状态

注意:checkboxcheckbox-group二者同名参数中,checkbox的参数优先级更高。

参数说明类型默认值可选值
v-model双向绑定某一个checkbox的值,如果将该变量设置为true,将会被选中String \ Number--
size组件整体的大小,单位rpxString \ Number--
label-sizelabel字体大小,单位rpxString \ Number--
icon-size图标大小,单位rpxString \ Number--
namecheckbox组件的标示符String \ Number--
shape形状,见上方说明String-square
disabled是否禁用Boolean-false / true
label-disabled是否禁止点击文本操作checkboxBoolean-false / true
active-color选中时的颜色,如设置CheckboxGroupactive-color将失效String--

CheckboxGroup Props

参数说明类型默认值可选值
max最多能选中多少个checkboxString \ Number999-
disabled是否禁用所有checkboxBooleanfalsetrue
icon-size图标大小,单位rpxString \ Number20-
size组件整体的大小,单位rpxString \ Number34-
shape形状,见上方说明Stringcirclesquare
active-color选中时的颜色,应用到所有子Checkbox组件String#2979ff-
label-disabled是否禁止点击文本操作checkboxBooleanfalsetrue
width 1.3.0checkbox的宽度,需带单位,如50%150rpxStringauto-
wrap 1.3.0是否每个checkbox占一行Booleanfalsetrue

Checkbox Event

事件名说明回调参数版本
change某个checkbox状态发生变化时触发,回调为一个对象detail = {value: [true或者false,true为被选中,否则反之], name: [通过props传递的name参数] }-

CheckboxGroup Event

事件名说明回调参数版本
change任一个checkbox状态发生变化时触发,回调为一个对象detail = array( [元素为被选中的checkboxname] )-