- Radio 单选框
- 概述
- 代码示例
- API
- Radio props
- Radio events
- RadioGroup props
- RadioGroup events
Radio 单选框
概述
基本组件-单选框。主要用于一组可选项单项选择,或者单独用于切换到选中状态。
代码示例
单独使用
使用 v-model 可以双向绑定数据。
<template>
<Radio v-model="single">Radio</Radio>
</template>
<script>
export default {
data () {
return {
single: false
}
}
}
</script>
组合使用
使用RadioGroup
实现一组互斥的选项组。在组合使用时,Radio
使用 label
来自动判断。每个 Radio 的内容可以自定义,如不填写则默认使用 label 的值。
<template>
<RadioGroup v-model="phone">
<Radio label="apple">
<Icon type="logo-apple"></Icon>
<span>Apple</span>
</Radio>
<Radio label="android">
<Icon type="logo-android"></Icon>
<span>Android</span>
</Radio>
<Radio label="windows">
<Icon type="logo-windows"></Icon>
<span>Windows</span>
</Radio>
</RadioGroup>
<RadioGroup v-model="animal">
<Radio label="金斑蝶"></Radio>
<Radio label="爪哇犀牛"></Radio>
<Radio label="印度黑羚"></Radio>
</RadioGroup>
</template>
<script>
export default {
data () {
return {
phone: 'apple',
animal: '爪哇犀牛'
}
}
}
</script>
不可用
通过设置disabled
属性来禁用单选框。
<template>
<Radio v-model="disabledSingle" disabled>Radio</Radio>
<RadioGroup v-model="disabledGroup">
<Radio label="金斑蝶" disabled></Radio>
<Radio label="爪哇犀牛"></Radio>
<Radio label="印度黑羚"></Radio>
</RadioGroup>
</template>
<script>
export default {
data () {
return {
disabledSingle: true,
disabledGroup: '爪哇犀牛'
}
}
}
</script>
垂直
设置属性 vertical
可以垂直显示,按钮样式下无效。
<template>
<RadioGroup v-model="vertical" vertical>
<Radio label="apple">
<Icon type="social-apple"></Icon>
<span>Apple</span>
</Radio>
<Radio label="android">
<Icon type="social-android"></Icon>
<span>Android</span>
</Radio>
<Radio label="windows">
<Icon type="social-windows"></Icon>
<span>Windows</span>
</Radio>
</RadioGroup>
</template>
<script>
export default {
data () {
return {
vertical: 'apple'
}
}
}
</script>
按钮样式
组合使用时可以设置属性type
为 button 来应用按钮的样式。
<template>
<RadioGroup v-model="button1" type="button">
<Radio label="北京"></Radio>
<Radio label="上海"></Radio>
<Radio label="深圳"></Radio>
<Radio label="杭州"></Radio>
</RadioGroup>
<RadioGroup v-model="button2" type="button">
<Radio label="北京"></Radio>
<Radio label="上海" disabled></Radio>
<Radio label="深圳"></Radio>
<Radio label="杭州"></Radio>
</RadioGroup>
<RadioGroup v-model="button3" type="button">
<Radio label="北京" disabled></Radio>
<Radio label="上海" disabled></Radio>
<Radio label="深圳" disabled></Radio>
<Radio label="杭州" disabled></Radio>
</RadioGroup>
</template>
<script>
export default {
data () {
return {
button1: '北京',
button2: '北京',
button3: '北京'
}
}
}
</script>
尺寸
通过设置属性size
为large
或small
将按钮样式设置为大和小尺寸,不设置为默认(中)尺寸。
<template>
<RadioGroup v-model="button4" type="button" size="large">
<Radio label="北京"></Radio>
<Radio label="上海"></Radio>
<Radio label="深圳"></Radio>
<Radio label="杭州"></Radio>
</RadioGroup>
<RadioGroup v-model="button5" type="button">
<Radio label="北京"></Radio>
<Radio label="上海"></Radio>
<Radio label="深圳"></Radio>
<Radio label="杭州"></Radio>
</RadioGroup>
<RadioGroup v-model="button6" type="button" size="small">
<Radio label="北京"></Radio>
<Radio label="上海"></Radio>
<Radio label="深圳"></Radio>
<Radio label="杭州"></Radio>
</RadioGroup>
</template>
<script>
export default {
data () {
return {
button4: '北京',
button5: '北京',
button6: '北京'
}
}
}
</script>
API
Radio props
属性 | 说明 | 类型 | 默认值 |
---|---|---|---|
value | 只在单独使用时有效。可以使用 v-model 双向绑定数据 | Boolean | false |
label | 只在组合使用时有效。指定当前选项的 value 值,组合会自动判断当前选择的项目 | String | Number | - |
disabled | 是否禁用当前项 | Boolean | false |
size | 单选框的尺寸,可选值为 large 、small 、default 或者不设置 | String | - |
true-value | 选中时的值,当使用类似 1 和 0 来判断是否选中时会很有用 | String, Number, Boolean | true |
false-value | 没有选中时的值,当使用类似 1 和 0 来判断是否选中时会很有用 | String, Number, Boolean | false |
Radio events
事件名 | 说明 | 返回值 |
---|---|---|
on-change | 在选项状态发生改变时触发,返回当前状态。通过修改外部的数据改变时不会触发 | … |
RadioGroup props
属性 | 说明 | 类型 | 默认值 |
---|---|---|---|
value | 指定当前选中的项目数据。可以使用 v-model 双向绑定数据 | String | Number | - |
type | 可选值为 button 或不填,为 button 时使用按钮样式 | String | - |
size | 尺寸,可选值为large 、small 、default 或者不设置 | String | - |
vertical | 是否垂直排列,按钮样式下无效 | Boolean | false |
RadioGroup events
事件名 | 说明 | 返回值 |
---|---|---|
on-change | 在选项状态发生改变时触发,返回当前选中的项。通过修改外部的数据改变时不会触发 | … |