function BasicActionSheet() {
const [open, setOpen] = useState(false)
const actions = useMemo(
() => [
{ name: "选项一", value: "1" },
{ name: "选项二", value: "2" },
{ name: "选项三", value: "3" },
],
[],
)
return (
<>
<Cell clickable isLink title="基础用法" onClick={() => setOpen(true)} />
<ActionSheet
actions={actions}
open={open}
onSelect={() => setOpen(false)}
onClose={setOpen}
/>
</>
)
}
添加cancelText
后,会在底部展示取消按钮,点击后关闭当前面板并触发 onCancel
事件。
function ActionSheetWithCancel() {
const [open, setOpen] = useState(false)
const actions = useMemo(
() => [
{ name: "选项一", value: "1" },
{ name: "选项二", value: "2" },
{ name: "选项三", value: "3" },
],
[],
)
return (
<>
<Cell clickable isLink title="展示取消按钮" onClick={() => setOpen(true)} />
<ActionSheet
cancelText="取消"
actions={actions}
open={open}
onSelect={() => setOpen(false)}
onCancel={() => setOpen(false)}
onClose={setOpen}
/>
</>
)
}
通过 description
和 subname
添加描述信息
function ActionSheetWithDescription() {
const [open, setOpen] = useState(false)
const actions = useMemo(
() => [
{ name: "选项一", value: "1", subname: "这是一段描述信息" },
{ name: "选项二", value: "2" },
{ name: "选项三", value: "3" },
],
[],
)
return (
<>
<Cell clickable title="展示描述信息" isLink onClick={() => setOpen(true)} />
<ActionSheet
description="这是一段描述信息"
cancelText="取消"
actions={actions}
open={open}
onSelect={() => setOpen(false)}
onCancel={() => setOpen(false)}
onClose={setOpen}
/>
</>
)
}
通过 loading
和 disabled
将选项设置为加载状态或禁用状态,通过 style
,className
修改样式
function ActionSheetWithStatuses() {
const [open, setOpen] = useState(false)
const actions = useMemo(
() => [
{ name: "选项一", value: "1", style: { color: "#ee0a24" } },
{ name: "选项二", value: "2", disabled: true },
{ name: "选项三", value: "3", loading: true },
],
[],
)
return (
<>
<Cell clickable title="选项状态" isLink onClick={() => setOpen(true)} />
<ActionSheet
actions={actions}
cancelText="取消"
open={open}
onSelect={() => setOpen(false)}
onCancel={() => setOpen(false)}
onClose={setOpen}
/>
</>
)
}
使用 ActionSheet.Button
组件后,会在底部展示取消按钮,点击后关闭当前面板并触发 onCancel
事件。
使用ActionSheet.Action
组件添加选项, 通过 loading
和 disabled
将选项设置为加载状态或禁用状态
通过 ActionSheet.Header
组件可 以在菜单顶部显示描述信息,通过选项的 ActionSheet.Action.children
属性可以在 Action
文字的下侧展示描述信息。
function ActionSheetWithStatuses() {
const [open, setOpen] = useState(true)
return (
<ActionSheet open={open} onSelect={() => setOpen(false)} onClose={setOpen}>
<ActionSheet.Action value="1" style={{ color: "#ee0a24" }} name="着色选项" />
<ActionSheet.Action value="2" disabled name="禁止选项" />
<ActionSheet.Action value="3" loading name="选项三" />
<ActionSheet.Button onClick={() => setOpen(false)}>取消</ActionSheet.Button>
</ActionSheet>
)
}
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
defaultOpen | 默认是否显示动作面板 | boolean | false |
open | 是否显示动作面板 | boolean | false |
description v0.3.0-alpha.0 | 选项上方的描述信息 | ReactNode | - |
cancelText v0.3.0-alpha.0 | 取消按钮文字 | ReactNode | - |
actions v0.3.0-alpha.0 | 面板选项列表 | ActionSheetActionObject[] | - |
className | 样式类名 | string | - |
style | 样式对象 | CSSProperties | - |
rounded | 是否为圆角 | string | - |
safeArea | 安全区的位置,可选值为 top bottom | string | bottom |
参数 | 说明 | 类型 |
---|---|---|
name | 标题 | ReactNode |
subname | 二级标题 | ReactNode |
disabled | 是否为禁用状态 | boolean |
loading | 是否为加载状态 | boolean |
value | 值 | any |
style | ||
className |
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
className | 样式类名 | string | - |
style | 样式对象 | CSSProperties | - |
duration | 动画时长,单位毫秒 | number | string | 300 |
closeable | 点击是否可以关闭 | boolean | true |
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
className | 样式类名 | string | - |
style | 样式对象 | CSSProperties | - |
title | 标题 | string | - |
children | 描述信息 | string | - |
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
className | 样式类名 | string | - |
style | 样式对象 | CSSProperties | - |
name | 标题 | string | - |
value | 选项值 | string | - |
disabled | 是否为禁用状态 | boolean | - |
loading | 是否为加载状态 | boolean | - |
children | 描述信息 | string | - |
参数 | 说明 | 类型 | 默认值 |
---|---|---|---|
className | 按钮类名 | string | - |
style | 按钮样式 | CSSProperties | - |
type | 按钮类型,可选值为 cancel | string | button |
children | 按钮内容 | string | - |
事件名 | 说明 | 回调参数 |
---|---|---|
onSelect | 点击选项时触发,禁用或加载状态下不会触发 | event: ActionSheet.ActionEvent |
onCancel | 点击取消按钮时触发 | - |
onClose | 关闭面板时触发 | - |
组件提供了下列 CSS 变量,可用于自定义样式,使用方法请参考 ConfigProvider 组件。
名称 | 默认值 | 描述 |
---|---|---|
—action-sheet-description-padding-bottom | var(—padding-md) | - |
—action-sheet-subname-margin-top | var(—padding-xs) | - |
—action-sheet-subname-color | var(—gray-6) | - |
—action-sheet-subname-font-size | var(—font-size-sm) | - |
—action-sheet-subname-line-height | var(—line-height-sm) | - |