docs/(plugins)/(elements)/list-classic.cn.mdx
此经典列表插件 - 具有严格嵌套规则的传统 HTML 规范列表:
ul/ol > li)列表插件 - 灵活的基于缩进的列表:
根据您的需求选择:
符合 HTML 的列表:
ul/ol > li 结构列表类型:
拖放:
快捷键:
-、*、1.、[ ])创建列表限制(使用 列表插件 获取这些功能):
对于更灵活的、类似 Word 的方法,请参阅列表插件。
</PackageInfo>添加列表功能的最快方法是使用 ListKit,它包含预配置的列表插件,带有 Plate UI 组件和键盘快捷键。
BulletedListElement:渲染无序列表元素。NumberedListElement:渲染有序列表元素。TaskListElement:渲染带复选框的任务列表元素。将套件添加到您的插件中:
import { createPlateEditor } from 'platejs/react';
import { ListKit } from '@/components/editor/plugins/list-classic-kit';
const editor = createPlateEditor({
plugins: [
// ...其他插件,
...ListKit,
],
});
npm install @platejs/list-classic
在创建编辑器时,将列表插件包含在您的 Plate 插件数组中。
import { ListPlugin, BulletedListPlugin, NumberedListPlugin, TaskListPlugin, ListItemPlugin } from '@platejs/list-classic/react';
import { createPlateEditor } from 'platejs/react';
const editor = createPlateEditor({
plugins: [
// ...其他插件,
ListPlugin,
BulletedListPlugin,
NumberedListPlugin,
TaskListPlugin,
ListItemPlugin,
],
});
使用自定义组件和键盘快捷键配置插件。
import { ListPlugin, BulletedListPlugin, NumberedListPlugin, TaskListPlugin, ListItemPlugin } from '@platejs/list-classic/react';
import { createPlateEditor } from 'platejs/react';
import { BulletedListElement, NumberedListElement, TaskListElement } from '@/components/ui/list-classic-node';
const editor = createPlateEditor({
plugins: [
// ...其他插件,
ListPlugin,
BulletedListPlugin.configure({
node: { component: BulletedListElement },
shortcuts: { toggle: { keys: 'mod+alt+5' } },
}),
NumberedListPlugin.configure({
node: { component: NumberedListElement },
shortcuts: { toggle: { keys: 'mod+alt+6' } },
}),
TaskListPlugin.configure({
node: { component: TaskListElement },
shortcuts: { toggle: { keys: 'mod+alt+7' } },
}),
ListItemPlugin,
],
});
node.component:分配 BulletedListElement、NumberedListElement 和 TaskListElement 来渲染列表元素。shortcuts.toggle:定义键盘快捷键来切换列表类型(mod+alt+5 用于项目符号,mod+alt+6 用于编号,mod+alt+7 用于任务列表)。您可以将 ListToolbarButton 添加到您的工具栏中以创建和管理列表。
使用 ListPlugin 时,请使用 turn-into-toolbar-classic-button,它包含所有列表类型(项目符号、编号和任务列表)。
使用 ListPlugin 时,请使用 insert-toolbar-classic-button,它包含所有列表类型(项目符号、编号和任务列表)。
ListPluginBulletedListPlugin用于无序(项目符号)列表的插件。
NumberedListPlugin用于有序(编号)列表的插件。
TaskListPlugin用于带复选框的任务列表的插件。
ListItemPlugin用于列表项的插件。
ListItemContentPlugin用于列表项内容的插件。
tf.ul.toggle()切换项目符号列表(ul)。
示例快捷键:Mod+Alt+5
tf.ol.toggle()切换编号列表(ol)。
示例快捷键:Mod+Alt+6
tf.taskList.toggle()切换带复选框的任务列表。
示例快捷键:Mod+Alt+7
getHighestEmptyList查找可以删除的最高端列表。列表的路径应该与 diffListPath 不同。如果最高端列表有 2 个或更多项目,则返回 liPath。它会向上遍历父列表,直到:
diffListPathgetListItemEntry返回给定路径的最近 li 和 ul/ol 包装节点条目(默认 = 选择)。
getListRoot向上搜索根列表元素。
<API name="getListRoot"> <APIParameters> <APIItem name="at" type="Path | TRange | Point | null" optional> 开始搜索的位置。 - **默认:** `editor.selection` </APIItem> </APIParameters> <APIReturns type="ElementEntry | undefined"> 根列表元素条目。 </APIReturns> </API>getListTypes获取支持的列表类型数组。
<API name="getListTypes"> <APIReturns type="string[]"> 支持的列表类型数组。 </APIReturns> </API>getTaskListProps根据提供的类型返回任务列表项的属性。
<API name="getTaskListProps"> <APIParameters> <APIItem name="type" type="string"> 要检查的列表类型。 </APIItem> <APIItem name="options" type="object" optional> 任务列表选项。 </APIItem> <APISubList> <APISubListItem parent="options" name="checked" type="boolean"> 任务项是否应被选中。 - **默认:** `false` </APISubListItem> </APISubList> </APIParameters> <APIReturns type="object | undefined"> 如果类型是任务列表,则返回带有 `checked` 属性的对象,否则返回 `undefined`。 </APIReturns> </API>moveListSiblingsAfterCursor将光标后的列表兄弟项移动到指定路径。
<API name="moveListSiblingsAfterCursor"> <APIOptions type="options"> <APIItem name="at" type="Path"> 光标位置路径。 </APIItem> <APIItem name="to" type="Path"> 目标路径。 </APIItem> </APIOptions> <APIReturns type="number"> 移动的兄弟项数量。 </APIReturns> </API>removeFirstListItem如果未嵌套且不是第一个子项,则删除第一个列表项。
<API name="removeFirstListItem"> <APIOptions type="options"> <APIItem name="list" type="ElementEntry"> 包含项的列表条目。 </APIItem> <APIItem name="listItem" type="ElementEntry"> 要删除的列表项。 </APIItem> </APIOptions> <APIReturns type="boolean"> 项是否被删除。 </APIReturns> </API>removeListItem删除列表项,如果有子列表则移动到父级。
<API name="removeListItem"> <APIOptions type="RemoveListItemOptions"> <APIItem name="list" type="ElementEntry"> 包含项的列表条目。 </APIItem> <APIItem name="listItem" type="ElementEntry"> 要删除的列表项。 </APIItem> <APIItem name="reverse" type="boolean" optional> 是否反转子列表项。 - **默认:** `true` </APIItem> </APIOptions> <APIReturns type="boolean"> 项是否被删除。 </APIReturns> </API>someList检查选择是否在特定类型的列表内。
<API name="someList"> <APIParameters> <APIItem name="type" type="string"> 要检查的列表类型。 </APIItem> </APIParameters> <APIReturns type="boolean"> 选择是否在指定的列表类型中。 </APIReturns> </API>unindentListItems减少列表项的缩进级别。
<API name="unindentListItems"> <APIOptions type="UnindentListItemsOptions"> 取消缩进的目标路径。 </APIOptions> </API>unwrapList移除选中项的列表格式。
<API name="unwrapList"> <APIOptions type="options"> <APIItem name="at" type="Path" optional> 取消包装的目标路径。 </APIItem> </APIOptions> </API>useListToolbarButton列表工具栏按钮的行为钩子。
<API name="useListToolbarButton"> <APIState> <APIItem name="pressed" type="boolean"> 按钮按下状态。 </APIItem> <APIItem name="nodeType" type="string"> 列表节点类型。 - **默认:** `BulletedListPlugin.key` </APIItem> </APIState> <APIReturns type="object"> <APIItem name="props" type="object"> 工具栏按钮的属性。 </APIItem> <APISubList> <APISubListItem parent="props" name="pressed" type="boolean"> 按钮按下状态。 </APISubListItem> <APISubListItem parent="props" name="onClick" type="function"> 切换列表并聚焦编辑器的处理函数。 </APISubListItem> </APISubList> </APIReturns> </API>useTodoListElementState管理任务列表项状态的钩子。
<API name="useTodoListElementState"> <APIState> <APIItem name="element" type="TTodoListItemElement"> 任务列表项元素。 </APIItem> </APIState> <APIReturns type="object"> <APIItem name="checked" type="boolean"> 任务项是否被选中。 </APIItem> <APIItem name="readOnly" type="boolean"> 编辑器是否处于只读模式。 </APIItem> <APIItem name="onCheckedChange" type="function"> 切换选中状态的处理函数。 </APIItem> </APIReturns> </API>useTodoListElement获取任务列表项复选框属性的钩子。
<API name="useTodoListElement"> <APIState> <APIItem name="checked" type="boolean"> 任务项是否被选中。 </APIItem> <APIItem name="readOnly" type="boolean"> 编辑器是否处于只读模式。 </APIItem> <APIItem name="onCheckedChange" type="function"> 切换选中状态的处理函数。 </APIItem> </APIState> <APIReturns type="object"> <APIItem name="checkboxProps" type="object"> 要扩展到复选框组件的属性。 </APIItem> </APIReturns> </API>