VUE 富文本(vue2-editor)


1. 概述

1.1 说明

在项目中,会需要使用富文本编辑器去编辑或保存文档、图片、视频等信息去描述某一个物品的详细信息与介绍。可使用vue的图文编辑vue2-editor去处理这些事情。

1.2 vue2-editor安装

   npm install vue2-editor --save 安装至项目中

1.3 富文本使用

  在使用vue2-editor的vue页面文件中,需要引入import { VueEditor } from 'vue2-editor' ,然后在components中进行注册图文编辑,然后对图文编辑器组件进行配置处理。

<template>
  <div>
    <vue2-editor v-model="htmlStr" :editorToolbar="customToolbar"></vue2-editor>
  </div>
</template>
<script>
  import {VueEditor} from 'vue2-editor'
  export default {
    name: 'Vue2Editor',
    data() {
      return {
        htmlStr: '',
        customToolbar: [
          ['bold', 'italic', 'underline'],
          [{'list': 'ordered'}, {'list': 'bullet'}],
          [{'indent': '-""'}, {'indent': '+""'}],
          [{'header': '2'}], ['clean'], [{'align': 'center'}, {'align': 'justify'}, {'align': 'right'}]
        ]
      }
    },
    methods: {},
  }
</script>
<style>
</style>

  vue2-editor相关配置描述:

    

  vue2-editor事件描述:

     

   vue2-editor工具栏描述:

    

 

2. 代码

2.1 代码示例

  做成一个公用组件在需要使用的地方进行引入调用

<template>
  <div>
    <vue2-editor v-model="strHtml" useCustomImageHandler @imageAdded="handleImageAdded" :id='id' :editorToolbar="customToolbar" :disabled='!!disabled'></vue2-editor>
  </div>
</template>
<script>
  import { VueEditor } from 'vue2-editor'
  import {defaultBar} from './editorToolBar.js'
  export default {
    name: 'Vue2Editor',
    props: ['content','disabled'],
    data() {
      return {
        strHtml: this.content,
        uploaderUrl: 'https://up.qbox.me',//上传路径放至七牛
        imgDomain: 'http://xxx.xxx.net/',//文件所在域名
        id: this.uniqueId(),
        customToolbar:defaultBar
      }
    },
    components: {
      'vue2-editor': VueEditor
    },
    watch: {
      strHtml(newval) {
        //实时监控编辑器内容变化,使父组件能够实时获取输入内容
        this.$emit('change', newval);
      },
      content(newval) {
        //父组件实时更新数据流向子组件
        this.strHtml = newval
      }
    },
    methods: {
      handleImageAdded(file, Editor, cursorLocation, resetUploader) {
        /**
         * 上传图片操作(上传至七牛)
         let formData = new FormData();
         let type = file.name.split('.');
         if (type.length < 2) {
        return false
      }
         type = type.pop();
         //获取七牛验证token
         this.getToken(type).then(res => {
        formData.append('file', file);
        formData.append('key', res.key);
        formData.append('token', res.token);
        this.$http({
          method: 'post',
          data: formData,
          headers: {
            'Content-Type': 'multipart/form-data'
          },
          url: this.uploaderUrl
        }).then(result => {
          let url = this.imgDomain + result.data.key // 获取URL
          if(type.indexOf('png') > -1 || type.indexOf('jpg') > -1 || type.indexOf('jpeg') > -1){
            Editor.insertEmbed(cursorLocation, 'image', url);//图片
          } else {
            Editor.insertEmbed(cursorLocation, 'video', url);//视频
          }
          resetUploader()
        }).catch(erro => {
          console.log(erro)
        })
      })
         * **/
        //把获取到的图片url 插入到鼠标所在位置 回显图片
        Editor.insertEmbed(cursorLocation, 'image', url);
        resetUploader();
      },
      uniqueId() {
        let rdNum = ('' + Date.now()).slice(-8);
        let str = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz_';
        let len = str.length;
        let res = '';
        for (let i = 0; i < 8; i++) {
          res += str[Math.floor(Math.random() * len)];
        }
        return res + rdNum;
      },
    },
  }
</script>

2.2 editorToolbar配置

export let defaultBar =  [
  [{ 'header': [false, 1, 2, 3, 4, 5, 6, ] }],
  ['bold', 'italic', 'underline', 'strike'],        // toggled buttons
  [{'align': ['','center','right','justify']}],
  ['blockquote'],
  [{ 'list': 'ordered'}, { 'list': 'bullet' }, { 'list': 'check' }],
  [{ 'script': 'sub'}, { 'script': 'super' }],      // superscript/subscript
  [{ 'indent': '-1'}, { 'indent': '+1' }],          // outdent/indent
  [{ 'color': [] }, { 'background': [] }],          // dropdown with defaults from theme
  ['link', 'image'],
  ['clean'],                                     // remove formatting button
]

 

 

  


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM