react quill中图片上传由默认转成base64改成上传到服务器的方法


Posted in Javascript onOctober 30, 2019

使用react-quill富文本编辑器,里面处理图片是默认转成base64,提交到后台的时候文件太大,因此这里改写处理image的逻辑,改成上传到服务器。

具体代码如下:

配置1

import Quill from 'quill'
import ReactQuill from 'react-quill'
import 'react-quill/dist/quill.core.css'
import 'react-quill/dist/quill.snow.css'
import QuillEmoji from 'quill-emoji'
import 'quill-emoji/dist/quill-emoji.css'

Quill.register({
  'modules/emoji-toolbar': QuillEmoji.ToolbarEmoji,
  // 'modules/emoji-textarea': QuillEmoji.TextAreaEmoji,
  'modules/emoji-shortname': QuillEmoji.ShortNameEmoji
})

const toolbarContainer = [
  [{ 'size': ['small', false, 'large', 'huge'] }], // custom dropdown
  [{ 'font': [] }],
  [{ 'header': 1 }, { 'header': 2 }],        // custom button values
  ['bold', 'italic', 'underline', 'strike'],    // toggled buttons
  [{ 'align': [] }],
  [{ 'indent': '-1' }, { 'indent': '+1' }],     // outdent/indent
  [{ 'direction': 'rtl' }],             // text direction
  [{ 'script': 'sub' }, { 'script': 'super' }],   // superscript/subscript
  ['blockquote', 'code-block'],

  [{ 'list': 'ordered' }, { 'list': 'bullet' }],
  [{ 'color': [] }, { 'background': [] }],
  ['emoji', 'image', 'video', 'link'],

  ['clean']
]

配置2

<ReactQuill
  ref={ref => this.quillRef = ref}
  placeholder="填写活动详情~"
  theme="snow"
  value={this.state.detailTpl}
  onChange={this.handleChangeDetail}
  modules={{
    toolbar: {
      container: toolbarContainer,
      handlers: {
        image: this.imageHandler
      }
    },
    'emoji-toolbar': true,
    // 'emoji-textarea': true,
    'emoji-shortname': true,
  }}
/>

图片处理方法

imageHandler = () => {
  this.quillEditor = this.quillRef.getEditor()
  const input = document.createElement('input')
  input.setAttribute('type', 'file')
  input.setAttribute('accept', 'image/*')
  input.click()
  input.onchange = async () => {
    const file = input.files[0]
    const formData = new FormData()
    formData.append('quill-image', file)
    const res = await uploadFile(formData) 
    const range = this.quillEditor.getSelection()
    const link = res.data[0].url

    // this part the image is inserted
    // by 'image' option below, you just have to put src(link) of img here. 
    this.quillEditor.insertEmbed(range.index, 'image', link)
  }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
xml分页+ajax请求数据源+dom取结果实例代码
Oct 31 Javascript
Json对象替换字符串占位符实现代码
Nov 17 Javascript
javascript history对象(历史记录)使用方法(实现浏览器前进后退)
Jan 07 Javascript
JavaScript计算两个日期时间段内日期的方法
Mar 16 Javascript
Jquery日历插件制作简单日历
Oct 28 Javascript
跟我学习javascript的call(),apply(),bind()与回调
Nov 16 Javascript
解决Layui数据表格中checkbox位置不居中的方法
Aug 15 Javascript
vue+axios+element ui 实现全局loading加载示例
Sep 11 Javascript
vue实现条件判断动态绑定样式的方法
Sep 29 Javascript
小程序显示弹窗时禁止下层的内容滚动实现方法
Mar 20 Javascript
详解关于React-Router4.0跳转不置顶解决方案
May 10 Javascript
解决vant的Toast组件时提示not defined的问题
Nov 11 Javascript
vue - vue.config.js中devServer配置方式
Oct 30 #Javascript
vue2.x 通过后端接口代理,获取qq音乐api的数据示例
Oct 30 #Javascript
vue中更改数组中属性,在页面中不生效的解决方法
Oct 30 #Javascript
基于JavaScript实现单例模式
Oct 30 #Javascript
vue解决使用$http获取数据时报错的问题
Oct 30 #Javascript
茶余饭后聊聊Vue3.0响应式数据那些事儿
Oct 30 #Javascript
vue请求服务器数据后绑定不上的解决方法
Oct 30 #Javascript
You might like
xajax写的留言本
2006/11/25 PHP
对squid中refresh_pattern的一些理解和建议
2009/04/17 PHP
php中mt_rand()随机数函数用法
2014/11/24 PHP
php实现检查文章是否被百度收录
2015/01/27 PHP
深入理解PHP+Mysql分布式事务与解决方案
2020/12/03 PHP
js小技巧--自动隐藏红叉叉
2007/08/13 Javascript
编写可维护面向对象的JavaScript代码[翻译]
2011/02/12 Javascript
javascript模版引擎-tmpl的bug修复与性能优化分析
2011/10/23 Javascript
js自动闭合html标签(自动补全html标记)
2012/10/04 Javascript
jquery实现简单的拖拽效果实例兼容所有主流浏览器
2013/06/21 Javascript
js读取注册表的键值示例
2013/09/25 Javascript
在每个匹配元素的外部插入新元素的方法
2013/12/20 Javascript
javascript获取form里的表单元素的示例代码
2014/02/14 Javascript
JavaScript闭包详解
2015/02/02 Javascript
JS+CSS实现模仿浏览器网页字符查找功能的方法
2015/02/26 Javascript
使用window.prompt()实现弹出用户输入的对话框
2015/04/13 Javascript
vue引入jq插件的实例讲解
2017/09/12 Javascript
JS设计模式之惰性模式(二)
2017/09/29 Javascript
Vue3.0结合bootstrap创建多页面应用
2019/05/28 Javascript
微信小程序new Date()方法失效问题解决方法
2019/07/29 Javascript
在Vue中使用Echarts实例图的方法实例
2020/10/10 Javascript
[45:59]完美世界DOTA2联赛PWL S2 FTD vs GXR 第二场 11.22
2020/11/24 DOTA
Python2中文处理纪要的实现方法
2018/03/10 Python
Python字符串、整数、和浮点型数相互转换实例
2018/08/04 Python
python实现栅栏加解密 支持密钥加密
2019/03/20 Python
Python 实现Numpy中找出array中最大值所对应的行和列
2019/11/26 Python
pytorch下大型数据集(大型图片)的导入方式
2020/01/08 Python
Python跑循环时内存泄露的解决方法
2020/01/13 Python
keras训练浅层卷积网络并保存和加载模型实例
2020/07/02 Python
使用pandas实现筛选出指定列值所对应的行
2020/12/13 Python
美国厨房和园艺工具网上商店:Nestneed
2019/08/24 全球购物
仓库主管的岗位职责
2013/12/04 职场文书
员工培训心得体会
2013/12/30 职场文书
法人授权委托书格式
2014/04/08 职场文书
单位个人查摆问题及整改措施
2014/10/28 职场文书
初中重阳节活动总结
2015/05/05 职场文书