Components

复选框

一种允许用户在选中和未选中之间切换的控件。

import * as React from "react";
import { Checkbox } from "radix-ui";
import { CheckIcon } from "@radix-ui/react-icons";
import "./styles.css";
const CheckboxDemo = () => (
<form>
<div style={{ display: "flex", alignItems: "center" }}>
<Checkbox.Root className="CheckboxRoot" defaultChecked id="c1">
<Checkbox.Indicator className="CheckboxIndicator">
<CheckIcon />
</Checkbox.Indicator>
</Checkbox.Root>
<label className="Label" htmlFor="c1">
Accept terms and conditions.
</label>
</div>
</form>
);
export default CheckboxDemo;

Features

    支持不确定状态。

    完全的键盘导航。

    可以是受控或非受控的。

安装

从命令行安装组件。

npm install @radix-ui/react-checkbox

解剖结构

导入所有部分并将它们组合在一起。

import { Checkbox } from "radix-ui";
export default () => (
<Checkbox.Root>
<Checkbox.Indicator />
</Checkbox.Root>
);

API 参考

Root

包含复选框的所有部分。当在 form 中使用时,将渲染一个 input 以确保事件正确传播。

PropTypeDefault
asChild
boolean
false
defaultChecked
boolean | 'indeterminate'
No default value
checked
boolean | 'indeterminate'
No default value
onCheckedChange
function
No default value
disabled
boolean
No default value
required
boolean
No default value
name
string
No default value
value
string
on
Data attributeValues
[data-state]"checked" | "unchecked" | "indeterminate"
[data-disabled]

禁用时存在

Indicator

在复选框处于选中或不确定状态时渲染。您可以直接为此元素设置样式,或者可以将其作为包装器放入图标,或者两者都可以。

PropTypeDefault
asChild
boolean
false
forceMount
boolean
No default value
Data attributeValues
[data-state]"checked" | "unchecked" | "indeterminate"
[data-disabled]

禁用时存在

示例

不确定状态

您可以通过控制其状态将复选框设置为 indeterminate

import { DividerHorizontalIcon, CheckIcon } from "@radix-ui/react-icons";
import { Checkbox } from "radix-ui";
export default () => {
const [checked, setChecked] = React.useState("indeterminate");
return (
<>
<StyledCheckbox checked={checked} onCheckedChange={setChecked}>
<Checkbox.Indicator>
{checked === "indeterminate" && <DividerHorizontalIcon />}
{checked === true && <CheckIcon />}
</Checkbox.Indicator>
</StyledCheckbox>
<button type="button" onClick={() => setChecked((prevIsChecked) => prevIsChecked === "indeterminate" ? false : "indeterminate", ) } >
切换不确定状态
</button>
</>
);
};

可访问性

遵循 三态复选框 WAI-ARIA 设计模式

键盘交互

KeyDescription
Space
选中/取消选中复选框。