1
100%
Files
'use client';
import * as React from 'react';
import { Plate, usePlateEditor } from 'platejs/react';
import { EditorKit } from '@/components/editor/editor-kit';
import { Editor, EditorContainer } from '@/components/ui/editor';
import { DEMO_VALUES } from './values/demo-values';
export default function Demo({ id }: { id: string }) {
const editor = usePlateEditor({
plugins: EditorKit,
value: DEMO_VALUES[id],
});
return (
<Plate editor={editor}>
<EditorContainer variant="demo">
<Editor />
</EditorContainer>
</Plate>
);
}
Text alignment controls for blocks.
align-demo


功能特性
- 为段落、标题等块级元素设置文本对齐方式
- 支持左对齐、右对齐、居中对齐和两端对齐
- 向目标块元素注入
align属性
套件使用
安装
最快捷的文本对齐实现方式是使用 AlignKit,它包含了预配置好的 TextAlignPlugin,可作用于段落、标题、图片和媒体元素。
'use client';
import { TextAlignPlugin } from '@platejs/basic-styles/react';
import { KEYS } from 'platejs';
export const AlignKit = [
TextAlignPlugin.configure({
inject: {
nodeProps: {
defaultNodeValue: 'start',
nodeKey: 'align',
styleKey: 'textAlign',
validNodeValues: ['start', 'left', 'center', 'right', 'end', 'justify'],
},
targetPlugins: [...KEYS.heading, KEYS.p, KEYS.img, KEYS.mediaEmbed],
},
}),
];
- 配置
Paragraph、Heading、Image和Media元素支持align属性 - 提供对齐选项:
start、left、center、right、end、justify
添加套件
将套件添加到插件列表:
import { createPlateEditor } from 'platejs/react';
import { AlignKit } from '@/components/editor/plugins/align-kit';
const editor = createPlateEditor({
plugins: [
// ...其他插件
...AlignKit,
],
});手动配置
安装
pnpm add @platejs/basic-styles
添加插件
在创建编辑器时,将 TextAlignPlugin 加入 Plate 插件数组。
import { TextAlignPlugin } from '@platejs/basic-styles/react';
import { createPlateEditor } from 'platejs/react';
const editor = createPlateEditor({
plugins: [
// ...其他插件
TextAlignPlugin,
],
});配置插件
可以配置 TextAlignPlugin 来指定目标元素和定义对齐选项。
import { TextAlignPlugin } from '@platejs/basic-styles/react';
import { KEYS } from 'platejs';
import { createPlateEditor } from 'platejs/react';
const editor = createPlateEditor({
plugins: [
// ...其他插件
TextAlignPlugin.configure({
inject: {
nodeProps: {
nodeKey: 'align',
defaultNodeValue: 'start',
styleKey: 'textAlign',
validNodeValues: ['start', 'left', 'center', 'right', 'end', 'justify'],
},
targetPlugins: [...KEYS.heading, KEYS.p],
},
}),
],
});inject.nodeProps.nodeKey: 注入到目标元素的属性名(默认为align)。如需使用其他属性名可设置为'textAlign'inject.nodeProps.defaultNodeValue: 设置默认对齐方式(start)inject.nodeProps.styleKey: 将注入属性映射到 CSS 的textAlign属性inject.nodeProps.validNodeValues: 定义有效的对齐值用于 UI 控制inject.targetPlugins: 插件键名数组,指定哪些元素类型会接收对齐属性
添加工具栏按钮
可以在工具栏中添加 AlignToolbarButton 来控制文本对齐。
插件
TextAlignPlugin
用于设置块级元素内文本对齐的插件。它会向 inject.targetPlugins 指定的元素注入 align 属性。
转换方法
tf.textAlign.setNodes
为已配置为此插件目标的选定块节点设置对齐方式。