import Vue from 'vue';
import { Checkbox, CheckboxGroup } from 'vant';
Vue.use(Checkbox).use(CheckboxGroup);
通过v-model绑定 checkbox 的勾选状态
<van-checkbox v-model="checked">复选框</van-checkbox>
export default {
data() {
return {
checked: true
};
}
};
<van-checkbox v-model="checked" disabled>复选框</van-checkbox>
<van-checkbox v-model="checked" checked-color="#07c160">复选框</van-checkbox>
通过 icon 插槽自定义图标,可以通过slotProps判断是否为选中状态
<van-checkbox v-model="checked">
自定义图标
<img
slot="icon"
slot-scope="props"
:src="props.checked ? icon.active : icon.inactive"
>
</van-checkbox>
export default {
data() {
checked: true,
icon: {
active: 'https://img.yzcdn.cn/vant/user-active.png',
inactive: 'https://img.yzcdn.cn/vant/user-inactive.png'
}
}
}
与van-checkbox-group一起使用,选中值是一个数组,通过v-model绑定在van-checkbox-group上,数组中的项即为选中的Checkbox的name属性设置的值
<van-checkbox-group v-model="result">
<van-checkbox
v-for="(item, index) in list"
:key="item"
:name="item"
>
复选框 {{ item }}
</van-checkbox>
</van-checkbox-group>
export default {
data() {
return {
list: ['a', 'b', 'c'],
result: ['a', 'b']
};
}
};
<van-checkbox-group v-model="result" :max="2">
<van-checkbox
v-for="(item, index) in list"
:key="item"
:name="item"
>
复选框 {{ item }}
</van-checkbox>
</van-checkbox-group>
此时你需要再引入Cell和CellGroup组件,并通过 checkbox 的 toggle 方法手动触发切换
<van-checkbox-group v-model="result">
<van-cell-group>
<van-cell
v-for="(item, index) in list"
clickable
:key="item"
:title="`复选框 ${item}`"
@click="toggle(index)"
>
<van-checkbox
:name="item"
ref="checkboxes"
slot="right-icon"
/>
</van-cell>
</van-cell-group>
</van-checkbox-group>
export default {
methods: {
toggle(index) {
this.$refs.checkboxes[index].toggle();
}
}
}
| 参数 |
说明 |
类型 |
默认值 |
版本 |
| name |
标识符 |
any |
- |
- |
| shape |
形状,可选值为 square |
string |
round |
- |
| v-model |
是否为选中状态 |
boolean |
false |
- |
| disabled |
是否禁用复选框 |
boolean |
false |
- |
| icon-size |
图标大小,默认单位为px |
`string |
number` |
20px |
| label-disabled |
是否禁用复选框文本点击 |
boolean |
false |
- |
| label-position |
文本位置,可选值为 left |
string |
right |
- |
| checked-color |
选中状态颜色 |
string |
#1989fa |
- |
| 参数 |
说明 |
类型 |
默认值 |
版本 |
| v-model |
所有选中项的标识符 |
any[] |
- |
- |
| disabled |
是否禁用所有复选框 |
boolean |
false |
- |
| max |
设置最大可选数,0 为无限制 |
number |
0 |
- |
| 事件名 |
说明 |
回调参数 |
| change |
当绑定值变化时触发的事件 |
当前组件的值 |
| click |
点击复选框时触发 |
event: Event |
| 事件名 |
说明 |
回调参数 |
| change |
当绑定值变化时触发的事件 |
当前组件的值 |
| 名称 |
说明 |
SlotProps |
| default |
自定义文本 |
- |
| icon |
自定义图标 |
checked: 是否为选中状态 |
通过 ref 可以获取到 checkbox 实例并调用实例方法
| 方法名 |
参数 |
返回值 |
介绍 |
| toggle |
- |
- |
切换选中状态 |