Loading...
特性
- 灵活的块缩进:通过缩进将任何块类型(段落、标题等)转换为列表项。
- 简化结构:扁平的DOM结构,每个缩进的块都是独立的,不同于List Classic插件。
- 列表类型:支持项目符号列表(无序)和编号列表(有序)。
- Markdown快捷键:结合自动格式化插件,使用Markdown快捷键(
-
、*
、1.
)创建列表。
有关底层缩进系统的更多信息,请参阅缩进插件。
套件使用
安装
添加列表功能的最快方式是使用ListKit
,它包含预配置的ListPlugin
以及必需的缩进插件,针对段落、标题、引用块、代码块和折叠元素。
BlockList
:渲染列表包装元素,支持待办事项列表。- 包含
IndentKit
用于底层缩进系统。 - 配置
Paragraph
、Heading
、Blockquote
、CodeBlock
和Toggle
元素以支持列表功能。
添加套件
将套件添加到插件中:
import { createPlateEditor } from 'platejs/react';
import { ListKit } from '@/components/editor/plugins/list-kit';
const editor = createPlateEditor({
plugins: [
// ...其他插件,
...ListKit,
],
});
添加工具栏按钮
您可以将ListToolbarButton
添加到工具栏以创建和管理列表。
转换为工具栏按钮
您可以将以下项添加到转换为工具栏按钮中,将块转换为列表:
{
icon: <ListIcon />,
label: '项目符号列表',
value: KEYS.ul,
}
{
icon: <ListOrderedIcon />,
label: '编号列表',
value: KEYS.ol,
}
{
icon: <SquareIcon />,
label: '待办列表',
value: KEYS.listTodo,
}
手动使用
安装
pnpm add @platejs/list @platejs/indent
添加插件
在创建编辑器时,将IndentPlugin
和ListPlugin
都包含在Plate插件数组中。列表插件依赖于缩进插件。
import { IndentPlugin } from '@platejs/indent/react';
import { ListPlugin } from '@platejs/list/react';
import { createPlateEditor } from 'platejs/react';
const editor = createPlateEditor({
plugins: [
// ...其他插件,
IndentPlugin,
ListPlugin,
],
});
配置插件
您可以配置这两个插件以针对特定元素并自定义列表行为。
import { IndentPlugin } from '@platejs/indent/react';
import { ListPlugin } from '@platejs/list/react';
import { KEYS } from 'platejs';
import { createPlateEditor } from 'platejs/react';
import { BlockList } from '@/components/ui/block-list';
const editor = createPlateEditor({
plugins: [
// ...其他插件,
IndentPlugin.configure({
inject: {
targetPlugins: [...KEYS.heading, KEYS.p, KEYS.blockquote, KEYS.codeBlock],
},
}),
ListPlugin.configure({
inject: {
targetPlugins: [...KEYS.heading, KEYS.p, KEYS.blockquote, KEYS.codeBlock],
},
render: {
belowNodes: BlockList,
},
}),
],
});
inject.targetPlugins
:插件键的数组,指示哪些元素类型可以成为列表项。render.belowNodes
:分配BlockList
以渲染列表包装元素。
插件
ListPlugin
用于创建和管理列表的插件。它与缩进插件配合使用,提供灵活的列表功能,任何块都可以通过缩进转换为列表项。
API
getNextList
获取具有缩进列表的下一个兄弟entry。
getPreviousList
获取具有缩进列表的上一个兄弟entry。
indentList
增加所选块的缩进。
outdentList
减少所选块的缩进。
someList
检查所选块是否具有特定的列表样式类型。
toggleList
切换缩进列表。
类型
GetSiblingListOptions
用于提供在文本块中获取兄弟缩进列表的选项。
getPreviousEntry function
此函数用于从给定entry获取上一个兄弟entry。
getNextEntry function
此函数用于从给定entry获取下一个兄弟entry。
query function
此函数用于在查找过程中验证兄弟节点。 如果返回false,则检查下一个兄弟节点。
eqIndent boolean
指示当兄弟节点具有与当前节点相同的缩进级别时是否中断查找。如果为true,则在找到具有相同缩进级别的兄弟节点时停止查找。
breakQuery (node: TNode) => boolean | undefined
一个函数,接受
TNode
并返回布尔值或undefined。 此函数用于指定查找过程应停止的条件。breakOnLowerIndent boolean
指示当找到具有较低缩进级别的兄弟节点时是否中断查找。如果为true,则在找到具有较低缩进级别的兄弟节点时停止查找。
breakOnEqIndentNeqListStyleType boolean
指示当找到具有相同缩进级别但不同列表样式类型的兄弟节点时是否中断查找。如果为true,则在找到这样的兄弟节点时停止查找。
钩子
useListToolbarButton
缩进列表工具栏按钮的行为钩子。