问题描述
"nofollow" target="_blank" href="https://github.com/surmon-china/vue-quill-editor">vue-quill-editor。具体如何引用作者在项目中已经写得很明白了,我在这里就不再赘述。
"color: #800000">基础简介
1.vue-quill-editor是基于quill(github地址)适用于Vue2的富文本编辑器,所以对于quill的原生属性扩展也是支持的。quill文档地址
2.quill 中有许多扩展和自定义方法功能。比如图片的重定义大小、图片上传的点击处理等。
图片上传
通过查看quill项目issue。发现其中是有对图片上传这方面问题进行考虑和修改的。所以图片上传这个方案是可行的。接下来就是如何实现。
3.首先我们需要在项目中拿到quill的实例。这个在vue-quill-editor项目中有介绍如何获取。基本方法就是通过ref获取你的vue-quill-editor实例,再获取quill实例,代码如下。其中newEditor就是我的vue-quill-editor
this.$refs.newEditor.quill
4.在拿到实例后我们需要考虑如何图片上传并将url插入文本中。通过查找发现可以注册一个自定义的图片处理函数,当顶部的工具栏中的图片按钮被点击的时候,就会触发这个函数。然而在实际使用中你会发现这个函数并不像文档中所说的接收(image, callback)两个参数,image是你的图片,你只需要在callback中将传入处理后的url就可以。而是接收一个参数state,当被点击时就会触发这个函数,并传入state值----true。这里首先介绍一下,如何注册这个处理函数-imgHandler。这里要注意,注册函数要写在mounted生命周期钩子里。
mounted() { var vm =this var imgHandler = async function(state) { if (state) { //button is clicked } } vm.$refs.newEditor.quill.getModule("toolbar").addHandler("image", imgHandler) }
5.通过在stackflow查阅,发现就只能在imgHandler中自己实现点击上传和插入的功能。这样就在editor下面写一个不显示的input,并监听变化上传图片,获取其实例,当imgHandler被点击时,模拟input按钮被点击。代码变成如下示例。
mounted() { var vm =this var imgHandler = async function(image) { vm.addImgRange = vm.$refs.newEditor.quill.getSelection() if (image) { var fileInput = document.getElementById(vm.uniqueId) //隐藏的file文本ID fileInput.click() //加一个触发事件 } } vm.$refs.newEditor.quill.getModule("toolbar").addHandler("image", imgHandler) }
6.最后是input的点击上传和图片url的插入。
HTML代码
<div v-loading="imageLoading" element-loading-text="请稍等,图片上传中"> <quill-editor ref="newEditor" :options="newOption" style="height: 200px; margin-bottom: 54px" v-model="editorContent" @change="editorChange"> </quill-editor> <form action="" method="post" enctype="multipart/form-data" id="uploadFormMulti"> <input style="display: none" :id="uniqueId" type="file" name="avator" multiple accept="image/jpg,image/jpeg,image/png,image/gif" @change="uploadImg('uploadFormMulti')"><!--style="display: none"--> </form> </div>
vue代码
uploadImg: async function(id) { var vm = this vm.imageLoading = true var formData = new FormData($('#' + id)[0]) try { const url = await vm.uploadImgReq(formData)// 自定义的图片上传函数 if (url != null && url.length > 0) { var value = url vm.addImgRange = vm.$refs.newEditor.quill.getSelection() value = value.indexOf('http') != -1 "图片增加失败") } document.getElementById(vm.uniqueId).value='' } catch ({message: msg}) { document.getElementById(vm.uniqueId).value='' vm.$message.warning(msg) } vm.imageLoading = false },
到这里就大功告成啦。如果有什么错误、问题或者更好的解决方案欢迎指正讨论~
最后,在解决这个问题的时候,顺便把ImageResize集成到了控件中。具体实现比较简单可以参考vue-quill-editor中的demo示例
import Quill from 'quill' import { ImageResize } from '../modules/ImageResize.js' Quill.register('modules/imageResize', ImageResize)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
更新日志
- 凤飞飞《我们的主题曲》飞跃制作[正版原抓WAV+CUE]
- 刘嘉亮《亮情歌2》[WAV+CUE][1G]
- 红馆40·谭咏麟《歌者恋歌浓情30年演唱会》3CD[低速原抓WAV+CUE][1.8G]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[320K/MP3][193.25MB]
- 【轻音乐】曼托凡尼乐团《精选辑》2CD.1998[FLAC+CUE整轨]
- 邝美云《心中有爱》1989年香港DMIJP版1MTO东芝首版[WAV+CUE]
- 群星《情叹-发烧女声DSD》天籁女声发烧碟[WAV+CUE]
- 刘纬武《睡眠宝宝竖琴童谣 吉卜力工作室 白噪音安抚》[FLAC/分轨][748.03MB]
- 理想混蛋《Origin Sessions》[320K/MP3][37.47MB]
- 公馆青少年《我其实一点都不酷》[320K/MP3][78.78MB]
- 群星《情叹-发烧男声DSD》最值得珍藏的完美男声[WAV+CUE]
- 群星《国韵飘香·贵妃醉酒HQCD黑胶王》2CD[WAV]
- 卫兰《DAUGHTER》【低速原抓WAV+CUE】
- 公馆青少年《我其实一点都不酷》[FLAC/分轨][398.22MB]
- ZWEI《迟暮的花 (Explicit)》[320K/MP3][57.16MB]