# Radio 单选框

在一组备选项中进行单选。

# 引入

import PressRadio from 'press-ui/press-radio/press-radio';
import PressRadioGroup from 'press-ui/press-radio-group/press-radio-group';

export default {
  components: {
    PressRadio,
    PressRadioGroup,
  }
}

# 代码演示

# 基础用法

通过value绑定值当前选中项的 name 。

<press-radio-group :value="radio" @change="onChange">
  <press-radio name="1">单选框 1</press-radio>
  <press-radio name="2">单选框 2</press-radio>
</press-radio-group>
export default {
  data() {
    return {
      radio: '1',
    }
  },
  methods: {
    onChange(value) {
      this.radio = value;
    },
  }
};

# 水平排列

direction属性设置为horizontal后,单选框组会变成水平排列。

<press-radio-group
  :value="radio"
  @change="onChange"
  direction="horizontal"
>
  <press-radio name="1">单选框 1</press-radio>
  <press-radio name="2">单选框 2</press-radio>
</press-radio-group>

# 禁用状态

通过disabled属性禁止选项切换,在Radio上设置diabled可以禁用单个选项。

<press-radio-group :value="radio" disabled @change="onChange">
  <press-radio name="1">单选框 1</press-radio>
  <press-radio name="2">单选框 2</press-radio>
</press-radio-group>

# 自定义形状

shape属性设置为square,单选框的形状会变成方形。

<press-radio-group :value="radio" @change="onChange">
  <press-radio name="1" shape="square">单选框 1</press-radio>
  <press-radio name="2" shape="square">单选框 2</press-radio>
</press-radio-group>

# 自定义颜色

通过checked-color属性设置选中状态的图标颜色。

<press-radio-group :value="radio" @change="onChange">
  <press-radio name="1" checked-color="#07c160">单选框 1</press-radio>
  <press-radio name="2" checked-color="#07c160">单选框 2</press-radio>
</press-radio-group>

# 自定义大小

通过icon-size属性可以自定义图标的大小。

<press-radio-group :value="radio" @change="onChange">
  <press-radio name="1" icon-size="24px">单选框 1</press-radio>
  <press-radio name="2" icon-size="24px">单选框 2</press-radio>
</press-radio-group>

# 自定义图标

通过icon插槽自定义图标,需要设置use-icon-slot属性。

<press-radio-group :value="radio" @change="onChange">
  <press-radio use-icon-slot :value="radio" name="1">
    自定义图标
    <img slot="icon" :src="radio === '1' ? icon.active : icon.normal" />
  </press-radio>
  <press-radio use-icon-slot :value="radio" name="2">
    自定义图标
    <img slot="icon" :src="radio === '2' ? icon.active : icon.normal" />
  </press-radio>
</press-radio-group>
export default {
  data() {
    return {
      radio: true,
      icon: {
        normal: '//img.yzcdn.cn/icon-normal.png',
        active: '//img.yzcdn.cn/icon-active.png',
      },
    }
  },
  methods: {
    onChanges(value) {
      this.radio = value;
    },
  }
};

# 禁用文本点击

通过设置label-disabled属性可以禁用单选框文本点击。

<press-radio-group :value="radio" @change="onChange">
  <press-radio name="1" label-disabled>单选框 1</press-radio>
  <press-radio name="2" label-disabled>单选框 2</press-radio>
</press-radio-group>

# 与 Cell 组件一起使用

此时你需要再引入CellCellGroup组件。

<press-radio-group :value="radio" @change="onChange">
  <press-cell-group>
    <press-cell title="单选框 1" clickable data-name="1" @click="onClick">
      <press-radio slot="right-icon" name="1" />
    </press-cell>
    <press-cell title="单选框 2" clickable data-name="2" @click="onClick">
      <press-radio slot="right-icon" name="2" />
    </press-cell>
  </press-cell-group>
</press-radio-group>
export default {
  data() {
    return {
      radio: '1',
    }
  },
  methods: {
    onChange(value) {
      this.radio = value;
    },
    onClick(value) {
      this.radio = value;
    },
  }
};

# API

# RadioGroup Props

参数 说明 类型 默认值
name 在表单内提交时的标识符 string -
value 当前选中项的标识符 any -
disabled 是否禁用所有单选框 boolean false
direction 排列方向,可选值为 horizontal string vertical

# Radio Props

参数 说明 类型 默认值
name 标识符 string -
shape 形状,可选值为 square string round
disabled 是否为禁用状态 boolean false
label-disabled 是否禁用文本内容点击 boolean false
label-position 文本位置,可选值为 left string right
icon-size 图标大小,默认单位为px string | number 20px
checked-color 选中状态颜色 string #1989fa
use-icon-slot 是否使用 icon 插槽 boolean false
custom-class 根节点样式类 string -
icon-class 图标样式类 string -
label-class 描述信息样式类 string -

# Radio Event

事件名 说明 回调参数
@change 当绑定值变化时触发的事件 当前选中项的 name

# RadioGroup Event

事件名 说明 回调参数
@change 当绑定值变化时触发的事件 当前选中项的 name

# 在线调试

横屏