wangEditor复制粘贴无样式

1,vue中安装wangEditor

 使用的npm安装 npm install wangeditor --save

2,创建公用组件 

在components中创建wangEnduit文件夹

组件内容为

<template lang="html">
  <div class="editor">
    <div ref="toolbar" class="toolbar">
    </div>
    <div ref="editor" class="text">
    </div>
  </div>
</template>

<script>
  import E from ‘wangeditor‘
  export default {
    name: ‘editoritem‘,
    data() {
      return {
        // uploadPath,
        editor: null,
        info_: null
      }
    },
    model: {
      prop: ‘value‘,
      event: ‘change‘
    },
    props: {
      value: {
        type: String,
        default: ‘‘
      },
      isClear: {
        type: Boolean,
        default: false
      }
    },
    watch: {
      isClear(val) {
        // 触发清除文本域内容
        if (val) {
          this.editor.txt.clear()
          this.info_ = null
        }
      },
      value: function(value) {
        if (value !== this.editor.txt.html()) {
          this.editor.txt.html(this.value)
        }
      }
      //value为编辑框输入的内容,这里我监听了一下值,当父组件调用得时候,如果给value赋值了,子组件将会显示父组件赋给的值
    },
    mounted() {
      this.seteditor()
      this.editor.txt.html(this.value)
    },
    methods: {
      seteditor() {
        // http://192.168.2.125:8080/admin/storage/create
        this.editor = new E(this.$refs.toolbar, this.$refs.editor)
        this.editor.config.uploadImgShowBase64 = false // base 64 存储图片
        this.editor.config.uploadImgServer = ‘http://otp.cdinfotech.top/file/upload_images‘// 配置服务器端地址
        this.editor.config.uploadImgHeaders = { }// 自定义 header
        this.editor.config.uploadFileName = ‘file‘ // 后端接受上传文件的参数名
        this.editor.config.uploadImgMaxSize = 2 * 1024 * 1024 // 将图片大小限制为 2M
        this.editor.config.uploadImgMaxLength = 6 // 限制一次最多上传 3 张图片
        this.editor.config.uploadImgTimeout = 3 * 60 * 1000 // 设置超时时间
        this.editor.config.pasteFilterStyle = false; //复制粘贴携带样式
 
        // 配置菜单
        this.editor.config.menus = [
          ‘head‘, // 标题
          ‘bold‘, // 粗体
          ‘fontSize‘, // 字号
          ‘fontName‘, // 字体
          ‘italic‘, // 斜体
          ‘underline‘, // 下划线
          ‘strikeThrough‘, // 删除线
          ‘foreColor‘, // 文字颜色
          ‘backColor‘, // 背景颜色
          ‘link‘, // 插入链接
          ‘list‘, // 列表
          ‘justify‘, // 对齐方式
          ‘quote‘, // 引用
          ‘emoticon‘, // 表情
          ‘image‘, // 插入图片
          ‘table‘, // 表格
          ‘video‘, // 插入视频
          ‘code‘, // 插入代码
          ‘undo‘, // 撤销
          ‘redo‘, // 重复
          ‘fullscreen‘ // 全屏
        ]

        this.editor.config.uploadImgHooks = {
          fail: (xhr, editor, result) => {
            // 插入图片失败回调
          },
          success: (xhr, editor, result) => {
            // 图片上传成功回调
          },
          timeout: (xhr, editor) => {
            // 网络超时的回调
          },
          error: (xhr, editor) => {
            // 图片上传错误的回调
          },
          customInsert: (insertImg, result, editor) => {
            // 图片上传成功,插入图片的回调
            //result为上传图片成功的时候返回的数据,这里我打印了一下发现后台返回的是data:[{url:"路径的形式"},...]
            // console.log(result.data[0].url)
            //insertImg()为插入图片的函数
             //循环插入图片
            // for (let i = 0; i < 1; i++) {
              // console.log(result)
              let url = "http://otp.cdinfotech.top"+result.url
              insertImg(url)
            // }
          }
        }
        this.editor.config.onchange = (html) => {
          this.info_ = html // 绑定当前逐渐地值
          this.$emit(‘change‘, this.info_) // 将内容同步到父组件中
        }
        // 创建富文本编辑器
        this.editor.create()
      }
    }
  }
</script>

<style lang="css">
  .editor {
    width: 100%;
    margin: 0 auto;
    position: relative;
    z-index: 0;
  }
  .toolbar {
    border: 1px solid #ccc;
  }
  .text {
    border: 1px solid #ccc;
    min-height: 500px;
  }
</style>

 

3 在父组件中调用

<template>
<div>
<editor-bar
v-model="sss"
:value="sss"
:isClear="isClear"
@change="change"
></editor-bar>
</div>
</template>

<script>
import EditorBar from "@/components/wangEnduit";

export default {
data() {
return {
isClear: false,
detail: `1111111`,
sss:`<section id="isPasted" style="box-sizing: border-box; font-style: normal; font-weight: 400; text-align: justify; font-size: 16px;"><section style="position: static; box-sizing: border-box;"><section style="text-align: center; justify-content: center; display: flex; flex-flow: row nowrap; margin: 10px 0% 0px; position: static; box-sizing: border-box;"><section style="display: inline-block; width: auto; vertical-align: top; background-color: rgb(255, 237, 236); min-width: 10%; max-width: 100%; flex: 0 0 auto; height: auto; padding: 0px; align-self: stretch; box-sizing: border-box;"><section style="margin: 0px 0%; justify-content: center; position: static; box-sizing: border-box;"><section style="text-align: justify; color: rgb(255, 100, 97); font-size: 12px; letter-spacing: 1px; line-height: 1.7; padding: 0px 20px; box-sizing: border-box;"><p style="white-space: normal; margin: 0px; padding: 0px; box-sizing: border-box;">2021/09/03</p></section></section></section></section></section><section style="margin: 10px 0% 17px; text-align: center; justify-content: center; position: static; box-sizing: border-box;"><section style="display: inline-block; width: auto; vertical-align: top; background-color: rgb(255, 100, 97); line-height: 0; min-width: 10%; max-width: 100%; height: auto; box-sizing: border-box;"><section style="margin: 5px 0%; justify-content: center; position: static; box-sizing: border-box;"><section style="text-align: justify; color: rgb(255, 255, 255); letter-spacing: 1px; line-height: 1.8; padding: 0px 20px; box-sizing: border-box;"><p style="white-space: normal; margin: 0px; padding: 0px; box-sizing: border-box;"><strong style="box-sizing: border-box;">抗日战争胜利纪念日</strong></p></section></section><section style="justify-content: center; margin: 0px 0% -7px; position: static; box-sizing: border-box;"><section style="display: inline-block; width: 0px; height: 0px; vertical-align: top; overflow: hidden; border-style: solid; border-width: 7px 6px 0px; border-color: rgb(255, 100, 97) rgba(255, 255, 255, 0) rgba(255, 255, 255, 0); padding: 0px; box-sizing: border-box;"><section><br></section></section></section></section></section><section style="margin: 30px 0% 20px; position: static; box-sizing: border-box;"><section style="font-size: 15px; color: rgb(95, 95, 95); letter-spacing: 1px; line-height: 1.8; padding: 0px 28px; box-sizing: border-box;"><p style="margin: 0px 0px 10px; white-space: normal; padding: 0px; box-sizing: border-box;">中国人民抗日战争胜利纪念日,是每个中国人都该铭记的日子。铭记历史,吾辈自强!我们从未遗忘!</p><p style="white-space: normal; margin: 0px; padding: 0px; box-sizing: border-box;">如今,硝烟散去,和平安宁,然而曾经那段血泪写就的过去不能忘,那场不屈不挠的抗争不敢忘。铭记历史,吾辈自强!我们从未遗忘!</p></section></section><section style="position: static; box-sizing: border-box;">`
};
},
methods: {
change(val) {
this.sss = val
},
},
components: { EditorBar },
};
</script>

wangEditor复制粘贴无样式

上一篇:信息系统项目管理师10大管理47个过程域输入输出工具(项目范围管理)


下一篇:wireshark 实用过滤表达式(针对ip、协议、端口、长度和内容)