Switch开关
开关选择器。
何时使用#
需要表示开关状态/两种状态之间的切换时;
和
checkbox的区别是,切换switch会直接触发状态改变,而checkbox一般用于状态标记,需要和提交操作配合。
代码演示
import { Switch } from 'antd';
function onChange(checked) {
console.log(`switch to ${checked}`);
}
ReactDOM.render(<Switch defaultChecked onChange={onChange} />, mountNode);import { Switch, Icon } from 'antd';
ReactDOM.render(
<div>
<Switch checkedChildren="开" unCheckedChildren="关" defaultChecked />
<br />
<Switch checkedChildren="1" unCheckedChildren="0" />
<br />
<Switch
checkedChildren={<Icon type="check" />}
unCheckedChildren={<Icon type="close" />}
defaultChecked
/>
</div>,
mountNode,
);import { Switch } from 'antd';
ReactDOM.render(
<div>
<Switch loading defaultChecked />
<br />
<Switch size="small" loading />
</div>,
mountNode,
);import { Switch, Button } from 'antd';
class App extends React.Component {
state = {
disabled: true,
};
toggle = () => {
this.setState({
disabled: !this.state.disabled,
});
};
render() {
return (
<div>
<Switch disabled={this.state.disabled} defaultChecked />
<br />
<Button type="primary" onClick={this.toggle}>
Toggle disabled
</Button>
</div>
);
}
}
ReactDOM.render(<App />, mountNode);import { Switch } from 'antd';
ReactDOM.render(
<div>
<Switch defaultChecked />
<br />
<Switch size="small" defaultChecked />
</div>,
mountNode,
);API#
| 参数 | 说明 | 类型 | 默认值 | 版本 |
|---|---|---|---|---|
| autoFocus | 组件自动获取焦点 | boolean | false | 3.2.2 |
| checked | 指定当前是否选中 | boolean | false | |
| checkedChildren | 选中时的内容 | string|ReactNode | ||
| defaultChecked | 初始是否选中 | boolean | false | |
| disabled | 是否禁用 | boolean | false | 3.2.2 |
| loading | 加载中的开关 | boolean | false | |
| size | 开关大小,可选值:default small | string | default | |
| unCheckedChildren | 非选中时的内容 | string|ReactNode | ||
| onChange | 变化时回调函数 | Function(checked: boolean, event: Event) | ||
| onClick | 点击时回调函数 | Function(checked: boolean, event: Event) | 3.13.0 | |
| className | Switch 器类名 | string | - | 3.10.1 |
方法#
| 名称 | 描述 | 版本 |
|---|---|---|
| blur() | 移除焦点 | |
| focus() | 获取焦点 |