解决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获取和设置Select选项的常用方法总结
Jul 04 Javascript
Javascript实现页面跳转的几种方式分享
Oct 26 Javascript
用jquery修复在iframe下的页面锚点失效问题
Aug 22 Javascript
jQuery使用fadein方法实现渐出效果实例
Mar 27 Javascript
Bootstrap每天必学之警告框插件
Apr 26 Javascript
js捕捉键盘事件和按键键值的方法
Oct 10 Javascript
vue-loader教程介绍
Jun 14 Javascript
Angular ng-animate和ng-cookies用法详解
Apr 18 Javascript
vue2.0 移动端实现下拉刷新和上拉加载更多的示例
Apr 23 Javascript
React事件处理的机制及原理
Dec 03 Javascript
原生js实现的移动端可拖动进度条插件功能详解
Aug 15 Javascript
jQuery实现雪花飘落效果
Aug 02 jQuery
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调用Google translate_tts api实现代码
2013/08/07 PHP
php简单实现数组分页的方法
2016/04/30 PHP
微信支付开发告警通知实例
2016/07/12 PHP
php微信开发之谷歌测距
2018/06/14 PHP
获取焦点时,利用js定时器设定时间执行动作
2010/04/02 Javascript
关于可运行代码无法正常执行的使用说明
2010/05/13 Javascript
上传文件返回的json数据会被提示下载问题解决方案
2014/12/03 Javascript
JavaScript中三种异步上传文件方式
2016/03/06 Javascript
基于d3.js实现实时刷新的折线图
2016/08/03 Javascript
微信小程序 常见问题总结(4058,40013)及解决办法
2017/01/11 Javascript
深入研究React中setState源码
2017/11/17 Javascript
AngularJs 禁止模板缓存的方法
2017/11/28 Javascript
详解Javascript 中的 class、构造函数、工厂函数
2017/12/20 Javascript
浅谈Node框架接入ELK实践总结
2019/02/22 Javascript
微信小程序实现张图片合成为一张并下载
2019/07/16 Javascript
详解阿里Node.js技术文档之process模块学习指南
2021/01/04 Javascript
Python实现TCP/IP协议下的端口转发及重定向示例
2016/06/14 Python
Python编程实现的简单神经网络算法示例
2018/01/26 Python
TensorFlow神经网络优化策略学习
2018/03/09 Python
Python函数参数匹配模型通用规则keyword-only参数详解
2019/06/10 Python
Python适配器模式代码实现解析
2019/08/02 Python
keras训练曲线,混淆矩阵,CNN层输出可视化实例
2020/06/15 Python
Python LMDB库的使用示例
2021/02/14 Python
HTML5中的音频和视频媒体播放元素小结
2016/01/29 HTML / CSS
英国优质家居用品网上品牌:URBANARA
2018/06/01 全球购物
Lungolivigno Fashion官网:高级时装在线购物
2020/10/17 全球购物
大学毕业生通用自荐信范文
2013/10/31 职场文书
计算机通信工程专业毕业生推荐信
2013/12/24 职场文书
酒店个人求职信范文
2014/01/25 职场文书
《生命 生命》教学反思
2014/04/19 职场文书
车间安全生产标语
2014/06/06 职场文书
七夕活动策划方案
2014/08/16 职场文书
试用期员工工作自我评价
2014/09/10 职场文书
群众路线教育党员自我剖析材料
2014/10/06 职场文书
2014年办公室文秘工作总结
2014/12/09 职场文书
房产证明范本
2015/06/19 职场文书