当前位置:首页 > 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;
  }
});

添加工具栏

<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实现md编辑

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

相关文章

vue实现下拉层级

vue实现下拉层级

Vue实现下拉层级菜单 使用Vue实现下拉层级菜单可以通过递归组件或动态渲染的方式完成。以下是两种常见实现方法: 递归组件实现 创建一个递归组件处理多级菜单结构: <template…

vue 路由 实现

vue 路由 实现

Vue 路由实现方法 Vue Router 是 Vue.js 的官方路由管理器,用于构建单页面应用(SPA)。以下是实现 Vue 路由的详细步骤: 安装 Vue Router 通过 npm 或 ya…

vue实现批量

vue实现批量

Vue 实现批量操作的方法 在 Vue 中实现批量操作通常涉及选择多个项目并执行统一处理,例如批量删除、批量更新等。以下是几种常见实现方式: 表格多选批量操作 使用 el-table 配合复选框实现…

vue实现oauth

vue实现oauth

Vue 实现 OAuth 的步骤 安装必要的依赖 确保项目中安装了 axios 和 vue-router。OAuth 通常需要发送 HTTP 请求和处理路由跳转。 npm install axios…

vue实现看板

vue实现看板

Vue 实现看板功能 使用 Vue 实现看板功能可以通过组件化开发、状态管理和拖拽库结合完成。以下是一个完整的实现方案: 基础项目结构 src/ ├── components/ │ ├── Ka…

vue 实现筛选

vue 实现筛选

实现筛选功能的基本方法 在Vue中实现筛选功能通常涉及以下几个核心步骤: 数据绑定与筛选逻辑 使用v-model绑定筛选条件到Vue实例的数据属性,结合计算属性实现动态筛选: data() {…