前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >SimpleMDE - Vue-Markdown编辑器

SimpleMDE - Vue-Markdown编辑器

作者头像
RtyXmd
发布2018-08-30 14:44:08
1.5K0
发布2018-08-30 14:44:08
举报
文章被收录于专栏:前端vue前端vue
vue项目使用Markdow编辑器详解

源码

tips:
代码语言:javascript
复制
第一点:编辑器是带有顶部工具栏的,默认是在线获取FontAwesome
但是在国内要么访问慢,要么访问不了,所以需要再配置中设置自动下载字体图标为false
autoDownloadFontAwesome: false
然后再组件中引入FontAwesome

第二点:根据自己的需求做个性化设置,我本地调试的时候,引用样式不管用
所以我直接就把这个功能给取消了,没有在配置中取消(因为没找到方法)而是直接覆盖了样式
1.安装引入
代码语言:javascript
复制
npm install simplemde --save    //markdown编辑器
npm install font-awesome --save    //FontAwesome字体图标
npm install showdown --save    //转换markdown语法
2.新建markdown组件
代码语言:javascript
复制
//html
<template>
  <div class="simplemde-container" :style="{height:height+'px',zIndex:zIndex}">
    <textarea :id="id">
    </textarea>
  </div>
</template>

//js
import 'font-awesome/css/font-awesome.min.css'
import 'simplemde/dist/simplemde.min.css'
import SimpleMDE from 'simplemde'
export default {
  data () {
    return {
      simplemde: null,
      hasChange: false
    }
  },
  props: {
    value: String,
    id: {
      type: String
    },
    autofocus: {
      type: Boolean,
      default: false
    },
    placeholder: {
      type: String,
      default: ''
    },
    height: {
      type: Number,
      default: 150
    },
    zIndex: {
      type: Number,
      default: 10
    },
    toolbar: {
      type: Array
    }
  },
  watch: {
    value(val) {
      console.log(val)
      if (val === this.simplemde.value() && !this.hasChange) return
      this.simplemde.value(val)
    }
  },
  mounted() {
    this.simplemde = new SimpleMDE({
      element: document.getElementById(this.id || 'markdown-editor-' + +new Date()),
      autoDownloadFontAwesome: false,
      autofocus: this.autofocus,
      toolbar: this.toolbar,
      spellChecker: false,
      insertTexts: {
        link: ['[', ']( )']
      },
      // hideIcons: ['guide', 'heading', 'quote', 'image', 'preview', 'side-by-side', 'fullscreen'],
      placeholder: this.placeholder
    })
    if (this.value) {
      this.simplemde.value(this.value)
    }
    this.simplemde.codemirror.on('change', () => {
      if (this.hasChange) {
        this.hasChange = true
      }
      this.$emit('input', this.simplemde.value())
    })
  },
  destroyed() {
    this.simplemde.toTextArea()
    this.simplemde = null
  }
}

//css    根据自己的需求覆盖原样式
.simplemde-container>>>.CodeMirror {
  min-height: 150px;
  line-height: 20px;
}
.simplemde-container>>>.CodeMirror-scroll {
  min-height: 150px;
  max-height:200px;
}
.simplemde-container>>>.CodeMirror-code {
  padding-bottom: 40px;
}
.simplemde-container>>>.editor-statusbar {
  display: none;
}
.simplemde-container>>>.CodeMirror .CodeMirror-code .cm-link {
  color: #1890ff;
}
.simplemde-container>>>.CodeMirror .CodeMirror-code .cm-string.cm-url {
  color: #2d3b4d;
}
.simplemde-container>>>.CodeMirror .CodeMirror-code .cm-formatting-link-string.cm-url {
  padding: 0 2px;
  color: #E61E1E;
}
.simplemde-container >>> .editor-toolbar.fullscreen,
.simplemde-container >>> .CodeMirror-fullscreen {
  z-index: 1003;
}
.simplemde-container >>> .fa-columns,
.simplemde-container >>> .fa-arrows-alt,
.simplemde-container >>> .fa-eye,
.simplemde-container >>> .fa-question-circle,
.simplemde-container >>> .separator,
.simplemde-container >>> .fa-quote-left{
  display:none;
}
3.在页面中引入组件并使用
代码语言:javascript
复制
<template>
  <div class="components-container">
    <div class="editor-container">
      <markdown-editor id="contentEditor" ref="contentEditor" v-model="content" :height="300" :zIndex="20"></markdown-editor>
    </div>
    <button @click="markdown2Html">To HTML</button>
    <div v-html="html"></div>
  </div>
</template>

<script>
import MarkdownEditor from '@/components/markDown'
const content = `
**this is test**
* vue
* element
1. markdown
2. editor
## Simplemde
[link](https://www.baidu.com) 
![图片](https://i.imgur.com/sZlktY7.png)
`
export default {
  components: { MarkdownEditor },
  data () {
    return {
      content: content,
      html: ''
    }
  },
  methods: {
    markdown2Html() {
      import('showdown').then(showdown => {
        const converter = new showdown.Converter()
        this.html = converter.makeHtml(this.content)
      })
    }
  }
}
</script>
最终效果图

最终效果图

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.08.09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • vue项目使用Markdow编辑器详解
    • tips:
    • 1.安装引入
    • 2.新建markdown组件
    • 3.在页面中引入组件并使用
    • 最终效果图
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档