You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
4.9 KiB
4.9 KiB
📝 编辑器切换功能演示
🎯 功能概述
我已经成功为文章编辑组件实现了Markdown和富文本编辑器的切换功能,具有以下特点:
✨ 核心功能
-
编辑器类型选择器
- 富文本编辑器(TinyMCE):所见即所得,支持图片、视频、格式化
- Markdown编辑器:轻量级标记语言,支持代码高亮
-
智能切换机制
- 有内容时会提示用户确认切换
- 自动进行基本的格式转换
- 保存用户的编辑器偏好设置
-
数据持久化
- 编辑器类型保存到数据库(editor字段:1=富文本,2=Markdown)
- 本地存储用户偏好设置
- 编辑时自动恢复用户选择的编辑器类型
🔧 技术实现
1. 编辑器选择器UI
<div class="editor-selector-container">
<div class="editor-selector">
<span class="selector-label">编辑器类型:</span>
<a-radio-group
v-model:value="editor"
@change="onEditorTypeChange"
class="editor-radio-group"
>
<a-radio :value="1" class="editor-radio">
<span class="radio-content">
<span class="radio-icon">📝</span>
<span class="radio-text">富文本编辑器</span>
<span class="radio-desc">所见即所得,支持图片、视频、格式化</span>
</span>
</a-radio>
<a-radio :value="2" class="editor-radio">
<span class="radio-content">
<span class="radio-icon">📋</span>
<span class="radio-text">Markdown编辑器</span>
<span class="radio-desc">轻量级标记语言,支持代码高亮</span>
</span>
</a-radio>
</a-radio-group>
</div>
</div>
2. 切换处理逻辑
const onEditorTypeChange = (e: any) => {
const newEditorType = e.target.value;
const oldEditorType = editor.value;
// 如果有内容,提示用户确认切换
if (content.value && content.value.trim() !== '' && content.value !== '<p><br></p>') {
Modal.confirm({
title: '🔄 切换编辑器类型',
content: '切换编辑器类型可能会影响内容格式,是否继续?',
okText: '确认切换',
cancelText: '取消',
onOk: () => {
performEditorSwitch(newEditorType, oldEditorType);
},
onCancel: () => {
editor.value = oldEditorType;
}
});
} else {
performEditorSwitch(newEditorType, oldEditorType);
}
};
3. 格式转换功能
const convertContentFormat = (fromType: number, toType: number) => {
if (fromType === 1 && toType === 2) {
// 富文本转Markdown
let markdownContent = content.value
.replace(/<h1[^>]*>(.*?)<\/h1>/gi, '# $1\n\n')
.replace(/<h2[^>]*>(.*?)<\/h2>/gi, '## $1\n\n')
.replace(/<strong[^>]*>(.*?)<\/strong>/gi, '**$1**')
.replace(/<em[^>]*>(.*?)<\/em>/gi, '*$1*')
// ... 更多转换规则
content.value = markdownContent;
} else if (fromType === 2 && toType === 1) {
// Markdown转富文本
let htmlContent = content.value
.replace(/^# (.*$)/gim, '<h1>$1</h1>')
.replace(/^## (.*$)/gim, '<h2>$1</h2>')
.replace(/\*\*(.*?)\*\*/g, '<strong>$1</strong>')
.replace(/\*(.*?)\*/g, '<em>$1</em>')
// ... 更多转换规则
content.value = htmlContent;
}
};
4. 偏好设置管理
const initEditorPreference = () => {
// 优先使用数据库中保存的编辑器类型
if (form.editor && (form.editor === 1 || form.editor === 2)) {
editor.value = form.editor;
} else {
// 使用本地存储的偏好
const savedPreference = localStorage.getItem('cms_article_editor_preference');
if (savedPreference && (savedPreference === '1' || savedPreference === '2')) {
editor.value = parseInt(savedPreference);
} else {
editor.value = 1; // 默认富文本
}
}
};
🎨 样式设计
编辑器选择器采用了现代化的卡片设计:
- 渐变背景和阴影效果
- 清晰的图标和描述文字
- 响应式交互效果
- 与现有UI风格保持一致
📊 数据库字段
在CmsArticle模型中,editor
字段用于保存编辑器类型:
1
: 富文本编辑器2
: Markdown编辑器
🚀 使用方式
- 新建文章:系统会根据用户偏好自动选择编辑器类型
- 编辑文章:自动恢复文章创建时使用的编辑器类型
- 切换编辑器:用户可以随时切换,系统会智能处理格式转换
- 保存文章:编辑器类型会自动保存到数据库
💡 用户体验优化
- 智能提示:切换前会提示可能的格式影响
- 格式转换:自动进行基本的HTML↔Markdown转换
- 偏好记忆:记住用户的编辑器选择偏好
- 无缝切换:保持内容的连续性和一致性
这个功能让用户可以根据自己的习惯和需求选择最适合的编辑器,提供了更加灵活和人性化的编辑体验!