- 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 | 在选项状态发生改变时触发,返回当前选中的项。通过修改外部的数据改变时不会触发 | … |
