TagPicker 标签选择器
以标签的方式进行多选,同时支持新增选项
获取组件
import { TagPicker } from 'rsuite';
演示
默认
尺寸
撑满
分支
可新建
自定义
禁用与只读
异步
可访问性
ARIA 属性
- TagPicker 组件的
role
属性为combobox
。 - 有
aria-haspopup="listbox"
属性来指示 combobox 有一个弹出的列表框。 - 有
aria-expanded
属性来指示列表框是否打开。 - 有
aria-controls
属性来指示列表框元素的 ID。 - 有
aria-activedescendant
属性来指示焦点选项的 ID。 - 当设置了
label
,aria-labelledby
属性被添加到 combobox 元素和 listbox 元素上,并将值设置为label
的id
属性值。 - listbox 有
aria-multiselectable=true
属性来指示列表框是多选的。
键盘交互
- ↓ - 移动焦点到下一个选项。
- ↑ - 移动焦点到上一个选项。
- Enter - 选择焦点选项。
- Esc - 关闭列表框。
Props
<TagPicker>
属性名称 | 类型(默认值) |
描述 |
---|---|---|
cacheData | ItemDataType[] | 当异步搜索时,用于缓存 value 的选项 |
classPrefix | string ('picker') |
组件 CSS 类的前缀 |
cleanable | boolean (true) |
可以清除 |
container | HTMLElement | (() => HTMLElement) | 设置渲染的容器 |
creatable | boolean | 设置可以新建选项 |
data * | ItemDataType[] | 组件数据 |
defaultValue | string[] | 设置默认值 非受控 |
disabled | boolean | 禁用组件 |
disabledItemValues | string[] | 禁用选项 |
groupBy | string | 设置分组条件在 data 中的 key |
labelKey | string ('label') |
设置选项显示内容在 data 中的 key |
listProps | ListProps | 虚拟化长列表的相关属性 |
loading | boolean (false) |
是否显示一个加载中状态指示器 |
menuClassName | string | 应用于菜单 DOM 节点的 css class |
menuMaxHeight | number (320) |
设置 Dropdown 的最大高度 |
menuStyle | CSSProperties | 应用于菜单 DOM 节点的 style |
onChange | (value:string, event) => void | value 发生改变时的回调函数 |
onClean | (event) => void | 清空值时触发回调 |
onClose | () => void | 关闭回调函数 |
onCreate | (value: string[], item: ItemDataType, event) => void | 在设置 creatable ,创建新选项后的回调函数 |
onEnter | () => void | 显示前动画过渡的回调函数 |
onEntered | () => void | 显示后动画过渡的回调函数 |
onEntering | () => void | 显示中动画过渡的回调函数 |
onExit | () => void | 退出前动画过渡的回调函数 |
onExited | () => void | 退出后动画过渡的回调函数 |
onExiting | () => void | 退出中动画过渡的回调函数 |
onGroupTitleClick | (event) => void | 点击分组标题的回调函数 |
onOpen | () => void | 打开回调函数 |
onSearch | (searchKeyword: string, event) => void | 搜索的回调函数 |
onSelect | (value: string, item: ItemDataType , event) => void | 选项被点击选择后的回调函数 |
onTagRemove | (value: string, event: MouseEvent) => void | 移除标签时的回调函数 |
open | boolean | 是否打开 |
placeholder | ReactNode ('Select') |
占位符 |
placement | Placement('bottomStart') |
位置 |
preventOverflow | boolean | 防止浮动元素溢出 |
renderExtraFooter | () => ReactNode | 自定义页脚内容 |
renderMenu | (menu: ReactNode) => ReactNode | 自定义渲染菜单列表 |
renderMenuGroup | (groupTitle: ReactNode, item: ItemDataType) => ReactNode | 自定义选项组 |
renderMenuItem | (label: ReactNode, item: ItemDataType) => ReactNode | 自定义选项 |
renderMenuItemCheckbox | (checkboxProps: CheckboxProps) => ReactNode | 自定义选项复选框 |
renderValue | (value: string[], items: ItemDataType[], tags: ReactNode[]) => ReactNode | 自定义被选中的选项 |
searchable | boolean (true) |
可以搜索 |
searchBy | (keyword: string, label: ReactNode, item: ItemDataType) => boolean | 自定义搜索规则 |
size | 'lg' | 'md' | 'sm' | 'xs' ('md') |
设置组件尺寸 |
sort | (isGroup: boolean) => (a: any, b: any) => number | 对选项排序 |
tagProps | TagProps | 设置 Tag 的属性 |
toggleAs | ElementType ('a') |
为组件自定义元素类型 |
trigger | 'Enter' | 'Space' | 'Comma' ('Enter') |
设置创建标签的触发事件 |
value | string[] | 设置值 受控 |
valueKey | string ('value') |
设置选项值在 data 中的 key |
virtualized | boolean | 是否开启虚拟列表 |
ItemDataType
interface ItemDataType<V> {
/** The value of the option corresponds to the `valueKey` in the data. **/
value: V;
/** The content displayed by the option corresponds to the `labelKey` in the data. **/
label: ReactNode;
/**
* The data of the child option corresponds to the `childrenKey` in the data.
* Properties owned by tree structure components, such as TreePicker, Cascader.
*/
children?: ItemDataType<V>[];
/**
* Properties of grouping functional components, such as CheckPicker, InputPicker
*/
groupBy?: string;
/**
* The children under the current node are loading.
* Used for components that have cascading relationships and lazy loading of children. E.g. Cascader, MultiCascader
*/
loading?: boolean;
}
Placement
type Placement =
| 'bottomStart'
| 'bottomEnd'
| 'topStart'
| 'topEnd'
| 'leftStart'
| 'leftEnd'
| 'rightStart'
| 'rightEnd'
| 'auto'
| 'autoVerticalStart'
| 'autoVerticalEnd'
| 'autoHorizontalStart'
| 'autoHorizontalEnd';
ListProps
interface ListProps {
/**
* Size of a item in the direction being windowed.
*/
itemSize?: number | ((index: number) => number);
/**
* Scroll offset for initial render.
*/
initialScrollOffset?: number;
/**
* Called when the items rendered by the list change.
*/
onItemsRendered?: (props: ListOnItemsRenderedProps) => void;
/**
* Called when the list scroll positions changes, as a result of user scrolling or scroll-to method calls.
*/
onScroll?: (props: ListOnScrollProps) => void;
}