当前位置:首页 > VUE

vue实现md编辑

2026-01-19 14:44:12VUE

vue实现markdown编辑器

使用Vue实现Markdown编辑器可以借助现成的库或组件,以下是几种常见实现方式:

使用marked和highlight.js库

安装依赖库:

npm install marked highlight.js

创建Vue组件:

<template>
  <div class="markdown-editor">
    <textarea v-model="markdown"></textarea>
    <div v-html="compiledMarkdown" class="markdown-preview"></div>
  </div>
</template>

<script>
import marked from 'marked';
import hljs from 'highlight.js';

marked.setOptions({
  highlight: function(code, lang) {
    return hljs.highlightAuto(code, [lang]).value;
  }
});

export default {
  data() {
    return {
      markdown: '# Hello World'
    }
  },
  computed: {
    compiledMarkdown() {
      return marked(this.markdown);
    }
  }
}
</script>

<style>
.markdown-editor {
  display: flex;
}
textarea {
  width: 50%;
  min-height: 500px;
}
.markdown-preview {
  width: 50%;
  padding: 10px;
  border: 1px solid #ddd;
}
</style>

使用vue-markdown组件

安装vue-markdown:

npm install vue-markdown

基本用法:

<template>
  <div>
    <textarea v-model="content"></textarea>
    <vue-markdown :source="content"></vue-markdown>
  </div>
</template>

<script>
import VueMarkdown from 'vue-markdown'

export default {
  components: {
    VueMarkdown
  },
  data() {
    return {
      content: '# Markdown Content'
    }
  }
}
</script>

使用mavon-editor

mavon-editor是一个功能丰富的Markdown编辑器:

npm install mavon-editor

实现代码:

<template>
  <mavon-editor v-model="content"/>
</template>

<script>
import { mavonEditor } from 'mavon-editor'
import 'mavon-editor/dist/css/index.css'

export default {
  components: {
    mavonEditor
  },
  data() {
    return {
      content: ''
    }
  }
}
</script>

实现双向绑定实时预览

对于自定义实现,可以结合watch或computed属性实现实时预览:

<template>
  <div class="editor-container">
    <div class="editor-column">
      <textarea v-model="rawText"></textarea>
    </div>
    <div class="preview-column" v-html="compiledHtml"></div>
  </div>
</template>

<script>
import marked from 'marked';

export default {
  data() {
    return {
      rawText: ''
    }
  },
  computed: {
    compiledHtml() {
      return marked(this.rawText);
    }
  }
}
</script>

<style>
.editor-container {
  display: flex;
}
.editor-column, .preview-column {
  flex: 1;
  padding: 10px;
}
textarea {
  width: 100%;
  height: 500px;
}
</style>

添加扩展功能

支持代码高亮

import hljs from 'highlight.js';
import 'highlight.js/styles/github.css';

marked.setOptions({
  highlight: function(code, language) {
    const validLanguage = hljs.getLanguage(language) ? language : 'plaintext';
    return hljs.highlight(validLanguage, code).value;
  }
});

添加工具栏

vue实现md编辑

<template>
  <div>
    <div class="toolbar">
      <button @click="insertText('bold')">Bold</button>
      <button @click="insertText('*italic*')">Italic</button>
    </div>
    <textarea ref="editor" v-model="content"></textarea>
  </div>
</template>

<script>
export default {
  methods: {
    insertText(text) {
      const textarea = this.$refs.editor;
      const start = textarea.selectionStart;
      const end = textarea.selectionEnd;
      this.content = this.content.substring(0, start) + 
                    text + 
                    this.content.substring(end);
      this.$nextTick(() => {
        textarea.setSelectionRange(start + text.length, start + text.length);
        textarea.focus();
      });
    }
  }
}
</script>

注意事项

  • 使用v-html时要注意XSS攻击风险,确保内容可信或进行适当过滤
  • 大型项目推荐使用专门的Markdown编辑器组件如mavon-editor
  • 考虑添加撤销/重做功能时需要维护编辑历史状态
  • 移动端适配可能需要特殊处理文本区域大小和工具栏布局

以上方案可根据项目需求选择或组合使用,mavon-editor提供了开箱即用的完整解决方案,而自定义实现则提供更大灵活性。

标签: 编辑vue
分享给朋友:

相关文章

项目基于vue实现

项目基于vue实现

基于Vue实现项目的关键方法 搭建基础环境 安装Node.js和npm/yarn,确保开发环境具备运行Vue的能力。通过Vue CLI快速初始化项目结构,选择所需配置(如Babel、Router、Vu…

vue组件实现

vue组件实现

Vue 组件实现基础 Vue 组件是 Vue.js 的核心特性之一,允许将 UI 拆分为独立、可复用的模块。组件的实现包括定义、注册、数据传递和生命周期管理等。 定义组件 组件可以通过单文件组件(.…

vue实现截图

vue实现截图

Vue 实现截图的方法 使用 html2canvas 库 安装 html2canvas 库: npm install html2canvas 在 Vue 组件中使用: import html2ca…

vue插件实现

vue插件实现

Vue 插件实现方法 Vue 插件是一种向 Vue 应用程序添加全局功能的机制。插件可以包含全局指令、过滤器、混入、实例方法等。 插件的基本结构 一个 Vue 插件通常是一个对象或函数,需要暴露一个…

vue 实现视频

vue 实现视频

Vue 实现视频播放功能 使用 Vue 实现视频播放功能可以通过 HTML5 的 <video> 标签或第三方库(如 video.js)来实现。以下是两种常见的方法: 使用 HTML5…

vue实现动画

vue实现动画

Vue 实现动画的方法 Vue 提供了多种方式来实现动画效果,包括内置的过渡系统、第三方动画库以及直接操作 CSS 或 JavaScript 动画。 使用 Vue 内置过渡系统 Vue 的 <…