# 📝 编辑器切换功能演示
## 🎯 功能概述
我已经成功为文章编辑组件实现了Markdown和富文本编辑器的切换功能,具有以下特点:
### ✨ 核心功能
1. **编辑器类型选择器**
- 富文本编辑器(TinyMCE):所见即所得,支持图片、视频、格式化
- Markdown编辑器:轻量级标记语言,支持代码高亮
2. **智能切换机制**
- 有内容时会提示用户确认切换
- 自动进行基本的格式转换
- 保存用户的编辑器偏好设置
3. **数据持久化**
- 编辑器类型保存到数据库(editor字段:1=富文本,2=Markdown)
- 本地存储用户偏好设置
- 编辑时自动恢复用户选择的编辑器类型
### 🔧 技术实现
#### 1. 编辑器选择器UI
```vue
编辑器类型:
📝
富文本编辑器
所见即所得,支持图片、视频、格式化
📋
Markdown编辑器
轻量级标记语言,支持代码高亮
```
#### 2. 切换处理逻辑
```typescript
const onEditorTypeChange = (e: any) => {
const newEditorType = e.target.value;
const oldEditorType = editor.value;
// 如果有内容,提示用户确认切换
if (content.value && content.value.trim() !== '' && content.value !== '
') {
Modal.confirm({
title: '🔄 切换编辑器类型',
content: '切换编辑器类型可能会影响内容格式,是否继续?',
okText: '确认切换',
cancelText: '取消',
onOk: () => {
performEditorSwitch(newEditorType, oldEditorType);
},
onCancel: () => {
editor.value = oldEditorType;
}
});
} else {
performEditorSwitch(newEditorType, oldEditorType);
}
};
```
#### 3. 格式转换功能
```typescript
const convertContentFormat = (fromType: number, toType: number) => {
if (fromType === 1 && toType === 2) {
// 富文本转Markdown
let markdownContent = content.value
.replace(/]*>(.*?)<\/h1>/gi, '# $1\n\n')
.replace(/]*>(.*?)<\/h2>/gi, '## $1\n\n')
.replace(/]*>(.*?)<\/strong>/gi, '**$1**')
.replace(/]*>(.*?)<\/em>/gi, '*$1*')
// ... 更多转换规则
content.value = markdownContent;
} else if (fromType === 2 && toType === 1) {
// Markdown转富文本
let htmlContent = content.value
.replace(/^# (.*$)/gim, '$1
')
.replace(/^## (.*$)/gim, '$1
')
.replace(/\*\*(.*?)\*\*/g, '$1')
.replace(/\*(.*?)\*/g, '$1')
// ... 更多转换规则
content.value = htmlContent;
}
};
```
#### 4. 偏好设置管理
```typescript
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编辑器
### 🚀 使用方式
1. **新建文章**:系统会根据用户偏好自动选择编辑器类型
2. **编辑文章**:自动恢复文章创建时使用的编辑器类型
3. **切换编辑器**:用户可以随时切换,系统会智能处理格式转换
4. **保存文章**:编辑器类型会自动保存到数据库
### 💡 用户体验优化
- **智能提示**:切换前会提示可能的格式影响
- **格式转换**:自动进行基本的HTML↔Markdown转换
- **偏好记忆**:记住用户的编辑器选择偏好
- **无缝切换**:保持内容的连续性和一致性
这个功能让用户可以根据自己的习惯和需求选择最适合的编辑器,提供了更加灵活和人性化的编辑体验!