解决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 相关文章推荐
jquery序列化form表单使用ajax提交后处理返回的json数据
Mar 03 Javascript
js下将金额数字每三位一逗号分隔
Feb 19 Javascript
JavaScript数组实现数据结构中的队列与堆栈
May 26 Javascript
js改变透明度实现轮播图的算法
Aug 24 Javascript
bootstrap modal+gridview实现弹出框效果
Aug 15 Javascript
详解JavaScript中的六种错误类型
Sep 21 Javascript
小程序实现人脸识别功能(百度ai)
Dec 23 Javascript
Vue+ElementUI 中级联选择器Bug问题的解决
Jul 31 Javascript
在vant 中使用cell组件 定义图标该图片和位置操作
Nov 02 Javascript
解决vuex刷新数据消失问题
Nov 12 Javascript
微信小程序之高德地图多点路线规划过程示例详解
Jan 18 Javascript
详解JavaScript的计时器和按钮效果设置
Feb 18 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应用程序的七个习惯深入分析
2013/06/08 PHP
兼容ie和firefox js关闭代码
2008/12/11 Javascript
JSON 和 JavaScript eval使用说明
2010/06/13 Javascript
JavaScript性能优化 创建文档碎片(document.createDocumentFragment)
2010/07/13 Javascript
让你的博文自动带上缩址的实现代码,方便发到微博客上
2010/12/28 Javascript
Bootstrap每天必学之简单入门
2015/11/19 Javascript
基于jQuery Tipso插件实现消息提示框特效
2016/03/16 Javascript
用nodejs搭建websocket服务器
2017/01/23 NodeJs
超全面的javascript中变量命名规则
2017/02/09 Javascript
微信小程序之判断页面滚动方向的示例代码
2018/08/30 Javascript
jQuery Ajax实现Select多级关联动态绑定数据的实例代码
2018/10/26 jQuery
Vue组件Draggable实现拖拽功能
2018/12/01 Javascript
php结合js实现多条件组合查询
2019/05/28 Javascript
详解为element-ui的Select和Cascader添加弹层底部操作按钮
2020/02/07 Javascript
vue 使用 vue-pdf 实现pdf在线预览的示例代码
2020/04/26 Javascript
[04:49]期待西雅图之战 2016国际邀请赛中国区预选赛WINGS战队赛后采访
2016/06/29 DOTA
Python中对象迭代与反迭代的技巧总结
2016/09/17 Python
Python使用pip安装pySerial串口通讯模块
2018/04/20 Python
Python2与Python3的区别实例分析
2019/04/11 Python
python日期相关操作实例小结
2019/06/24 Python
python将excel转换为csv的代码方法总结
2019/07/03 Python
django rest framework 实现用户登录认证详解
2019/07/29 Python
Django框架HttpResponse对象用法实例分析
2019/11/01 Python
python烟花效果的代码实例
2020/02/25 Python
Tostadora意大利:定制T恤
2019/04/08 全球购物
联想英国官网:Lenovo英国
2019/07/17 全球购物
台湾专柜女包:KINAZ
2019/12/26 全球购物
教师群众路线教育实践活动学习笔记
2014/11/05 职场文书
安全生产先进个人总结
2015/02/15 职场文书
司机个人年终总结
2015/03/03 职场文书
销售经理助理岗位职责
2015/04/13 职场文书
黑白记忆观后感
2015/06/18 职场文书
运动会100米广播稿
2015/08/19 职场文书
2016中秋节广告语
2016/01/28 职场文书
成本低的5个创业项目:投资小、赚钱快
2019/08/20 职场文书
SQL注入篇学习之盲注/宽字节注入
2022/03/03 MySQL