vue-quill-editor插⼊图⽚路径太长问题解决⽅法
最近做项⽬的时候有⼀个发布新闻的需求,新闻编辑的时候要求能发布带格式的⽂本内容和能展⽰⽀持图⽚。
由于项⽬是⽤ Vue 开发的,所以编辑器的时候选了 vue-quill-editor 。编辑器长如下的样⼦:
现在的问题
但是这个编辑器会把插⼊的图⽚会转成 base64 位的编码,使得编辑器内容保存进数据库的时候会超出限制长度,从⽽报错。从问题来源着⼿
⾸先要明⽩导致这个问题的原因是 vue-quill-editor 编辑器默认把上传的图⽚给转成 base64 编码,那是不是有这么⼀个配置参数可以设置上传后图⽚的格式呢?经过⼀番⽂档的查,貌似是没有。但是提供了⼀个 handlers 可以⾃定义图⽚上传的⽅式,那就从这⾥下⽂章。⼤概意思是点击这个图⽚按钮的时候,会出发⼀个回调,可以在回调⾥触发⾃⼰的⽂件上传开关。这⾥我⽤的⽂件上传是 element-ui 的 el-upload。
安装vue-quill-editor
npm install vue-quill-editor --save
配置vue-quill-editor
配置 html
<quill-editor
v-model="t"
ref="myQuillEditor"
:options="editorOption"
class="ql-editor"
:class="operationType.includes('check') ? 'disabled' : ''"
:disabled="operationType.includes('check')"
>
</quill-editor>
导⼊vue-quill-editor 且设置components:
import { quillEditor } from 'vue-quill-editor'
export default {
components: {
quillEditor
}
}
设置options:
editorOption:{
modules: {
toolbar: {
container: [
['bold', 'italic', 'underline', 'strike'],
['blockquote', 'code-block'],
[{ 'list': 'ordered' }, { 'list': 'bullet' }],
[{ 'script': 'sub' }, { 'script': 'super' }],
[{ 'indent': '-1' }, { 'indent': '+1' }],
[{ 'size': ['small', false, 'large', 'huge'] }],
[{ 'header': [1, 2, 3, 4, 5, 6, false] }],
[{ 'color': [] }, { 'background': [] }],
[{ 'align': [] }],
['clean'],
editor bar
['link', 'image']
],
handlers: {
image: function(value) {
if (value) {
// 触发element-ui的⽂件上传
document.querySelector(".avatar-uploader input").click();
} else {
this.quill.format("image", false);
}
},
}
}
},
placeholder: '请输⼊',
},
引⼊相关style:
<style lang="scss">
@import '~quill/ss';
@import '~quill/dist/quill.snow.css';
@import '~quill/dist/quill.bubble.css';
</style>
配置el-upload
template:
<el-upload
ref="quillUploader"
class="avatar-uploader"
:action="serverUrl"
:show-file-list="false"
:auto-upload="false"
:on-change="onChangeQuill"
:before-upload="beforeUpload"
:limit="20"
:
multiple="true"
:accept="acceptFile">
</el-upload>
onChange的时候执⾏⽂件上传,这⾥的⽂件上传⽤的是腾讯的对象存储服务,cosUtils封装了⼀些对象存储的⼀些⼯具⽅法,你们可以⾃⾏替换成⾃⼰后端的上传接⼝。下⾯这段代码的⼤概意思是⽂件上传到对象存储服务器成功之后,拿到具体的图⽚地址,插⼊到编辑器光标所在的位置,这个时候图⽚就显⽰出来了。
onChangeQuill(file, fileList) {
let fileName = file.uid + file.name
cosUtils.putObject(fileName, file.raw, 'operate/', (err, data) => { // 新闻图⽚存到operate/⽬录下
console.log(err || data)
if (!err) {
let quill = this.$QuillEditor.quill
let length = Selection().index
// 图⽚上传到对象存储后的具体地址
let imgSrc = `qcloud/operate/${fileName}`
quill.insertEmbed(length, "image", imgSrc)
// 调整光标到最后
quill.setSelection(length + 1)
}
})
}
到此这篇关于vue-quill-editor插⼊图⽚路径太长问题解决⽅法的⽂章就介绍到这了,更多相关vue-quill-editor 图⽚路径内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!