vue富文本编辑器的使用_elementui富文本

vue富文本编辑器的使用_elementui富文本写好的富文本编辑器,附带功能齐全,复制即用!!!(Quill官方中文文档)一、安装二、注册1.在.main.js中注册富文本编辑器三、使用1.以下是写好的富文本编辑器,附带功能齐全(Quill官方中文文档)2.新建一个Editor文件夹,文件夹下创建一个index.vue文件,将此复制到vue文件里3.将Editor文件夹放入Vue项目的components组件包里方便其他页面直接引用富文本编辑器5.页面引入刚刚写好的富文本编辑器组件6.效果:………

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

一、安装

npm install quill --save

二、注册

1.在.main.js中注册富文本编辑器

Vue.use(VueEditor)

三、使用

1.以下是写好的富文本编辑器,附带功能齐全,复制即用!!!(Quill官方中文文档

2.新建一个Editor文件夹,文件夹下创建一个index.vue文件,将此复制到vue文件里

3.将Editor文件夹放入Vue项目的components组件包里方便其他页面直接引用富文本编辑器

<template>
  <div ref="editor" class="editor" :style="styles" />
</template>

<script>
import Quill from 'quill'
import 'quill/dist/quill.core.css'
import 'quill/dist/quill.snow.css'
import 'quill/dist/quill.bubble.css'

export default { 
   
  name: 'Editor',
  props: { 
   
    /* 编辑器的内容 */
    value: { 
   
      type: String,
      default: ''
    },
    /* 高度 */
    height: { 
   
      type: Number,
      default: null
    },
    /* 最小高度 */
    minHeight: { 
   
      type: Number,
      default: null
    }
  },
  data() { 
   
    return { 
   
      Quill: null,
      currentValue: '',
      options: { 
   
        theme: 'snow',
        bounds: document.body,
        debug: 'warn',
        modules: { 
   
          // 工具栏配置
          toolbar: [
            ['bold', 'italic', 'underline', 'strike'], // 加粗 斜体 下划线 删除线
            ['blockquote', 'code-block'], // 引用 代码块
            [{ 
    list: 'ordered' }, { 
    list: 'bullet' }], // 有序、无序列表
            [{ 
    indent: '-1' }, { 
    indent: '+1' }], // 缩进
            [{ 
    size: ['small', false, 'large', 'huge'] }], // 字体大小
            [{ 
    header: [1, 2, 3, 4, 5, 6, false] }], // 标题
            [{ 
    color: [] }, { 
    background: [] }], // 字体颜色、字体背景颜色
            [{ 
    align: [] }], // 对齐方式
            ['clean'], // 清除文本格式
            ['link', 'image', 'video'] // 链接、图片、视频
          ]
        },
        placeholder: '请输入内容',
        readOnly: false //只读模式 true
      }
    }
  },
  computed: { 
   
    styles() { 
   
      const style = { 
   }
      if (this.minHeight) { 
   
        style.minHeight = `${ 
     this.minHeight}px`
      }
      if (this.height) { 
   
        style.height = `${ 
     this.height}px`
      }
      return style
    }
  },
  watch: { 
   
    value: { 
   
      handler(val) { 
   
        if (val !== this.currentValue) { 
   
          this.currentValue = val === null ? '' : val
          if (this.Quill) { 
   
            this.Quill.pasteHTML(this.currentValue)
          }
        }
      },
      immediate: true
    }
  },
  mounted() { 
   
    this.init()
  },
  beforeDestroy() { 
   
    this.Quill = null
  },
  methods: { 
   
    init() { 
   
      const editor = this.$refs.editor
      this.Quill = new Quill(editor, this.options)
      this.Quill.pasteHTML(this.currentValue)
      this.Quill.on('text-change', (delta, oldDelta, source) => { 
   
        const html = this.$refs.editor.children[0].innerHTML
        const text = this.Quill.getText()
        const quill = this.Quill
        this.currentValue = html
        this.$emit('input', html)
        this.$emit('on-change', { 
    html, text, quill })
      })
      this.Quill.on('text-change', (delta, oldDelta, source) => { 
   
        this.$emit('on-text-change', delta, oldDelta, source)
      })
      this.Quill.on('selection-change', (range, oldRange, source) => { 
   
        this.$emit('on-selection-change', range, oldRange, source)
      })
      this.Quill.on('editor-change', (eventName, ...args) => { 
   
        this.$emit('on-editor-change', eventName, ...args)
      })
    }
  }
}
</script>

<style>
.editor, .ql-toolbar { 
   
  white-space: pre-wrap!important;
  line-height: normal !important;
}
.quill-img { 
   
  display: none;
}
.ql-snow .ql-tooltip[data-mode="link"]::before { 
   
  content: "请输入链接地址:";
}
.ql-snow .ql-tooltip.ql-editing a.ql-action::after { 
   
  border-right: 0;
  content: "保存";
  padding-right: 0;
}

.ql-snow .ql-tooltip[data-mode="video"]::before { 
   
  content: "请输入视频地址:";
}

.ql-snow .ql-picker.ql-size .ql-picker-label::before,
.ql-snow .ql-picker.ql-size .ql-picker-item::before { 
   
  content: "14px";
}
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="small"]::before,
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="small"]::before { 
   
  content: "10px";
}
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="large"]::before,
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="large"]::before { 
   
  content: "18px";
}
.ql-snow .ql-picker.ql-size .ql-picker-label[data-value="huge"]::before,
.ql-snow .ql-picker.ql-size .ql-picker-item[data-value="huge"]::before { 
   
  content: "32px";
}

.ql-snow .ql-picker.ql-header .ql-picker-label::before,
.ql-snow .ql-picker.ql-header .ql-picker-item::before { 
   
  content: "文本";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="1"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="1"]::before { 
   
  content: "标题1";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="2"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="2"]::before { 
   
  content: "标题2";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="3"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="3"]::before { 
   
  content: "标题3";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="4"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="4"]::before { 
   
  content: "标题4";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="5"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="5"]::before { 
   
  content: "标题5";
}
.ql-snow .ql-picker.ql-header .ql-picker-label[data-value="6"]::before,
.ql-snow .ql-picker.ql-header .ql-picker-item[data-value="6"]::before { 
   
  content: "标题6";
}

.ql-snow .ql-picker.ql-font .ql-picker-label::before,
.ql-snow .ql-picker.ql-font .ql-picker-item::before { 
   
  content: "标准字体";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value="serif"]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value="serif"]::before { 
   
  content: "衬线字体";
}
.ql-snow .ql-picker.ql-font .ql-picker-label[data-value="monospace"]::before,
.ql-snow .ql-picker.ql-font .ql-picker-item[data-value="monospace"]::before { 
   
  content: "等宽字体";
}
</style>

在这里插入图片描述

4.页面中的使用

<el-row>
  <el-col :span="24">
    <el-form-item label="发布内容" prop="content">
<!--富文本编辑器 此处必须设置富文本编辑器高度-->
      <editor v-model="form.content" :min-height="192" />
    </el-form-item>
  </el-col>
</el-row>

5.页面引入刚刚写好的富文本编辑器组件

import Editor from '@/public/components/Editor';
  //加载私有组件
  components: { 
   
    Editor
  },

6.效果:

在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182069.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月14日 下午2:16
下一篇 2022年10月14日 下午2:36


相关推荐

  • 从大量的IP访问记录中找到访问次数最多的IP

    从大量的IP访问记录中找到访问次数最多的IP

    2021年11月4日
    44
  • linux apache2配置_装了centos还可以装ubuntu吗

    linux apache2配置_装了centos还可以装ubuntu吗1、Apache2的配置文件Ubuntu中Apache的配置文件是//etc/apache2/apache2.conf。Apache在启动时会找到这个文件并自动读取该文件中的配置信息,而其他配置文件则是通过include指令包含进来的,在apache2.conf中可以看到这些引入行。当然,也可以将所有的配置全放在apache2.conf或者httpd.conf或者其他文件中,Apache这样

    2026年1月20日
    5
  • Codeforces 455B A Lot of Games(字典树+博弈)[通俗易懂]

    Codeforces 455B A Lot of Games(字典树+博弈)

    2022年1月26日
    52
  • C#中IntPtr类型

    1.C#中的IntPtr类型被称之为“平台特定的整数类型”,用于本机资源,例如窗口句柄。2.资源的大小取决于使用的硬件和操作系统,即此类型的实例在32位硬件和操作系统中将是32位,在64位硬件和操作系统中将是64位;但其大小总是足以包含系统的指针(因此也可以包含资源的名称)。3.在调用API函数时,类似含有窗口句柄参数(HANDLE)的原型函数,应显示地声明为IntPtr类型。4.In…

    2022年4月4日
    197
  • sorl入门

    sorl入门本教程是从别人的基础上借鉴整理的 Solr 是一个独立的企业级搜索应用服务器 它对外提供 API 接口 用户可以通过 http 请求 向搜索引擎服务器提交一定格式的 XML 文件 生成索引 solr 生成倒排索引 数据库生成的索引是二叉树索引 效率差距很大 也可以通过 HttpGet 操作提出查找请求 并得到 XML 格式的返回结果 Solr 是一个类似于 Google 或者 Bing 的全文检索引擎 Solr 是与搜索引擎

    2026年3月17日
    1
  • c语言中的异或运算_java中的异或运算符

    c语言中的异或运算_java中的异或运算符今天看到一位大神的博客,深受感触。决定也发一篇博客,证明一下我还活着。于是我翻看以前学习时做的一些笔记,整理了一下,得到了一个关于异或运算交换变量变量值的笔记。首先来看下面三组表达式,看起来他们都能实现交换两个变量的值。a=a^b;b=a^b;a=a^b;a=a^(b=b^(a=a^b));a^=b^=a^=b;可实际的情况是,前面2组表…

    2026年4月15日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号