解决vue-quill-editor上传内容由于图片是base64的导致字符太长的问题


Posted in Javascript onAugust 20, 2018

vue-quill-editor是个较为轻量级富文本框,相较于ueditor,开发更编辑,更加直观,如果大家伙在需求允许的情况下,还是会比较建议使用vue-quill-editor。

vue-quill-editor的使用方法在这边就不多说了,大家网上查下,一抓一大把

但是在使用vue-quill-editor有一个致命的问题,vue-quill-editor默认插入图片是直接将图片转为base64再放入内容中,如果图片比较大的话,富文本的内容就会很大,即使图片不大,只要图片较为多,篇幅较长,富文本的内容也是异常的大的,这就会给大家带来一些烦恼,我们可能更希望在提交富文本的内容的时候图片只是以图片地址提交,那这样一来我们要怎么去处理呢,接下来大家可以来理一理

还是老思路,既然我们可以希望不是直接将图片转成base64,那么我们可以采用选择完图片,即将图片上传服务器,服务器返回相应的图片链接,前端将图片链接插入到富文本的指定光标上即可,这样一来就可以实现我们的想要的效果了

首先,新建富文本组件QuillEditor.vue,利用iview的上传组件来上传选择完的图片(当然,其他的上传组件也是ok的)

<Upload
    id="iviewUp"
     ref="upload"
     :show-upload-list="false"
     :on-success="handleSingleSuccess"
     :format="['jpg','jpeg','png']"
     :max-size="2048"
     :headers="header"
     :on-format-error="handleFormatError"
     :before-upload="handleBeforeUpload()"
     type="drag"
     :action="serverUrl"
     style="display: none;width:0">
     <div style="width: 0">
       <Icon type="ios-camera" size="50"></Icon>
     </div>
   </Upload>
   <!--<Row>-->
    <quill-editor 
     v-model="detailContent" 
     ref="myQuillEditor" 
     :options="editorOption" 
     @blur="onEditorBlur($event)" @focus="onEditorFocus($event)"
     @change="onEditorChange($event)">
    </quill-editor>
   <!--</Row>-->

看到上面的代码有的的就会有疑问了,那上传好的图片要怎么插到富文本的指定光标里面呢,别慌,面包会有的,往下看,

handleSingleSuccess (res, file) {
   // res为图片服务器返回的数据
   // 获取富文本组件实例
   let vm = this
   let quill = this.$refs.myQuillEditor.quill
   console.log('res---', vm.$refs.myQuillEditor.quill.getSelection())
   // 如果上传成功
   if (res.res_code === '1') {
     // 获取光标所在位置
     let length = quill.getSelection().index;
     // 插入图片 res.info为服务器返回的图片地址
     quill.insertEmbed(length, 'image', res.result.url)
     // 调整光标到最后
     quill.setSelection(length + 1)
   } else {
     vm.$Message.error('图片插入失败')
   }
   // loading动画消失
   this.quillUpdateImg = false
  }

通过 this.$refs.myQuillEditor.quill.getSelection().index获取光标所在位置,将图片地址放在该位置即可

这样一来万事俱备,只欠东风了,这个时候大家会发现,那iview这个上传组件在页面上呢,我怎么实现点击富文本上的上传图片的按钮调用iview的上传组件的方法呢,

这个时候我们就要用到富文本中的配置属性editorOption,对editorOption进行图片上传的点击事件进行相应的配置即可,详情看下面代码

editorOption: { // 富文本框配置
     placeholder: '',
     theme: 'snow', // or 'bubble'
     modules: {
       toolbar: {
         container: toolbarOptions, // 工具栏
         handlers: {
           'image': function (value) {
 

if (value) {
               document.querySelector('#iviewUp input').click()
             } else {
               this.quill.format('image', false);
             }
           }
         }
       }
     }
   }

 document.querySelector('#iviewUp input') 这个就是相应的dom节点的点击事件,将其绑在富文本的图片按钮点击事件上好了,基本上大功告成。还是算比较简单的,希望可以供大家参考

总结

以上所述是小编给大家介绍的解决vue-quill-editor上传内容由于图片是base64的导致字符太长的问题,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JS+ACTIVEX实现网页选择本地目录路径对话框
Mar 18 Javascript
JQuery Tips相关(1)----关于$.Ready()
Aug 14 Javascript
JavaScript中九种常用排序算法
Sep 02 Javascript
javascript伸缩菜单栏实现代码分享
Nov 12 Javascript
基于jQuery实现收缩展开功能
Mar 18 Javascript
JavaScript动态生成二维码图片
Apr 20 Javascript
AngularJS自定义指令之复制指令实现方法
May 18 Javascript
import与export在node.js中的使用详解
Sep 28 Javascript
原生js+cookie实现购物车功能的方法分析
Dec 21 Javascript
对Vue beforeRouteEnter 的next执行时机详解
Aug 25 Javascript
layer关闭当前窗口页面以及确认取消按钮的方法
Sep 09 Javascript
JavaScript中layim之整合右键菜单的示例代码
Feb 06 Javascript
Vue2.0生命周期的理解
Aug 20 #Javascript
JavaScript作用域、闭包、对象与原型链概念及用法实例总结
Aug 20 #Javascript
RequireJS用法简单示例
Aug 20 #Javascript
JavaScript实现多态和继承的封装操作示例
Aug 20 #Javascript
浅谈微信小程序之官方UI框架we-ui使用教程
Aug 20 #Javascript
Layui给数据表格动态添加一行并跳转到添加行所在页的方法
Aug 20 #Javascript
微信小程序 MinUI组件库系列之badge徽章组件示例
Aug 20 #Javascript
You might like
PHP中模拟处理HTTP PUT请求的例子
2014/07/22 PHP
php格式化时间戳显示友好的时间实现思路及代码
2014/10/23 PHP
php+mysql数据库实现无限分类的方法
2014/12/12 PHP
详解PHP素材图片上传、下载功能
2019/04/12 PHP
php中文语义分析实现方法示例
2019/09/28 PHP
js两行代码按指定格式输出日期时间
2011/10/21 Javascript
JS 添加网页桌面快捷方式的代码详细整理
2012/12/27 Javascript
js 控制下拉菜单刷新的方法
2013/03/03 Javascript
JS/FLASH实现复制代码到剪贴板(兼容所有浏览器)
2013/05/27 Javascript
Jquery实现图片左右自动滚动示例
2013/09/25 Javascript
js 动态加载事件的几种方法总结
2013/12/25 Javascript
JavaScript的jQuery库插件的简要开发指南
2015/08/12 Javascript
前端JS面试中常见的算法问题总结
2016/12/23 Javascript
angular学习之从零搭建一个angular4.0项目
2017/07/10 Javascript
vue-router 源码实现前端路由的两种方式
2018/07/02 Javascript
Vue.set 全局操作简单示例
2019/09/19 Javascript
nodejs如何在package.json中设置多条启动命令
2020/03/16 NodeJs
vant组件中 dialog的确认按钮的回调事件操作
2020/11/04 Javascript
六个窍门助你提高Python运行效率
2015/06/09 Python
python查找指定具有相同内容文件的方法
2015/06/28 Python
Python如何实现守护进程的方法示例
2017/02/08 Python
Python中文分词工具之结巴分词用法实例总结【经典案例】
2017/04/15 Python
把csv文件转化为数组及数组的切片方法
2018/07/04 Python
python3使用matplotlib绘制散点图
2019/03/19 Python
使用Python给头像戴上圣诞帽的图像操作过程解析
2019/09/20 Python
基于Python共轭梯度法与最速下降法之间的对比
2020/04/02 Python
合作意向协议书范本
2014/03/31 职场文书
个人求职信格式范文
2015/03/20 职场文书
单身证明格式样本
2015/06/15 职场文书
婚礼嘉宾致辞
2015/07/28 职场文书
写作技巧:怎样写好一份优秀工作总结?
2019/08/14 职场文书
dubbo集成zipkin获取Traceid的实现
2021/07/26 Java/Android
Mysql8.0递归查询的简单用法示例
2021/08/04 MySQL
JavaScript中的LHS和RHS分析详情
2022/04/06 Javascript
Java工作中实用的代码优化技巧分享
2022/04/21 Java/Android
vue中data里面的数据相互使用方式
2022/06/05 Vue.js