Problems with using wangeditor rich text editing in Vue

Problems with using wangeditor rich text editing in Vue

wangEditor is a web rich text editor developed based on javascript and css. It is lightweight, simple, easy to use, open source and free.
It is still frequently used in our actual projects. Here is a case for your reference...

wangEditor documentation: https://www.wangeditor.com/

Rich text editor screenshot:

insert image description here
insert image description here
insert image description here

<!--Rich text editor. http://www.wangeditor.com/
Example of use:
<AppEditor v-model="content"></AppEditor>
-->
<template>
 <article ref="editor" class="AppEditor-root"></article>
</template>
<script>
 const E = require('wangeditor');
 export default {
  name: 'AppEditor',
  model: {
   prop: 'value',
   event: 'update:value',
  },
  props: {
   // value, v-model binding value: {type: String, default: ''},
   //Menu optionsmenus: {
    type: Array,
    default(){
     return [
      : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : : :
    },
   },
  },
  data(){
   return {
    editor: {}, // Editor object_value: '', // Content backup, used for judgment during watch, only changes when the editor is input};
  },
  computed: {},
  mounted(){
   this.initEditor();
  },
  watch:
   value(newValue, oldValue){
    // Editor onchange changes are not processed, only those from the parent component are processed to prevent text rollback bug
    if (newValue != this._value) {
     this.editor.txt.html(newValue);
    }
   },
  },
  methods: {
   initEditor(){
    let editor = new E(this.$refs.editor);
    Object.assign(editor.customConfig, {
     menus: this.menus,
     zIndex: 100,
     height: 200,
     pasteFilterStyle: false,
     onchange: (html) => {
      this._value = html; // Update _value
      this.$emit('update:value', html); // Update value
     },
     customUploadImg:((file, insert)=> {
      if(this.$utils.isEmpty(file)){
       return;
      }
      const msg = this.$Message.loading({
       content: 'Dear, the picture is being uploaded, please wait...',
       duration: 0
      });
      var params = new FormData();
      params.append('img', file[0]);
      this.$api.post('/synthesis/crm/picture/pictureUpload',params).then(res => {
       insert(res.data.imgUrl)
       setTimeout(msg, 0);
       this.$Message.success('Upload successful');
      })
     }),
     uploadImgHooks:{

      customInsert: function (insertImg, result, editor) {
       insertImg(result.url)
      }
     }
    });


    editor.create();
    editor.txt.html(this.value); // For asynchronous data acquisition, it cannot be bound immediately. Watch the judgment and process this.editor = editor;
   },
  },
 };
</script>
<style scoped lang="scss">
 .AppEditor-root{ border: 1px solid #f0f0f0; height: 400px !important;
  /deep/ .we-toolbar{ border: none !important; border-bottom: 1px solid #f0f0f0 !important; background-color: #fff !important;

  }
  /deep/ .we-text-container{ height: calc(100% - 43px) !important; border: none !important; z-index:1 !important;
   .we-text{ height: 100%; overflow-y: auto !important;}
  }
 }

</style>

This is the end of this article about the use of wangeditor rich text editing in Vue. For more relevant wangeditor rich text editing content, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • How to get the html and text of wangeditor in vue
  • How to use rich text editor wangEditor3 in Vue
  • Example of using the lightweight rich text editor wangEditor with vue
  • How to use wangEditor in vue and how to get focus by echoing data

<<:  Some notes on mysql create routine permissions

>>:  About MySQL innodb_autoinc_lock_mode

Recommend

Complete steps to upgrade Nginx http to https

The difference between http and https is For some...

How to customize more beautiful link prompt effect with CSS

Suggestion: Handwriting code as much as possible c...

The Complete List of MIME Types

What is MIME TYPE? 1. First, we need to understan...

How to use JS to check if an element is within the viewport

Preface Share two methods to monitor whether an e...

A problem with MySQL 5.5 deployment

MySQL deployment Currently, the company deploys M...

Canonical enables Linux desktop apps with Flutter (recommended)

Google's goal with Flutter has always been to...

How to construct a table index in MySQL

Table of contents Supports multiple types of filt...

Web design must also first have a comprehensive image positioning of the website

⑴ Content determines form. First enrich the conten...

Summary of changes in the use of axios in vue3 study notes

Table of contents 1. Basic use of axio 2. How to ...

Summary of block-level elements, inline elements, and variable elements

Block element p - paragraph pre - format text tabl...

MySQL performance optimization tips

MySQL Performance Optimization MySQL is widely us...

Summary of common commands for Ubuntu servers

Most of the commands below need to be entered in ...