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 相关文章推荐
Javascript生成json的函数代码(可以用php的json_decode解码)
Jun 11 Javascript
js去字符串前后空格5种实现方法及比较
Apr 03 Javascript
jQuery - css() 方法示例详解
Jan 16 Javascript
浅谈JavaScript中运算符的优先级
Jul 07 Javascript
JS基于myFocus库实现各种功能的tab选项卡切换效果
Sep 19 Javascript
关于JS 预解释的相关理解
Jun 28 Javascript
jQuery 实现ajax传入参数含有特殊字符的方法总结
Oct 17 Javascript
JavaScript中for循环的几种写法与效率总结
Feb 03 Javascript
angularJS+requireJS实现controller及directive的按需加载示例
Feb 20 Javascript
使用 jQuery 实现表单验证功能
Jul 05 jQuery
基于bootstrap实现多个下拉框同时搜索功能
Jul 19 Javascript
4个顶级JavaScript高级文本编辑器
Oct 10 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
php调用C代码的实现方法
2014/03/11 PHP
WordPress中创建用户角色的相关PHP函数使用详解
2015/12/25 PHP
PHP实现小偷程序实例
2016/10/31 PHP
Yii框架视图、视图布局、视图数据块操作示例
2019/10/14 PHP
JavaScript 克隆数组最简单的方法
2009/02/12 Javascript
jquery简单的拖动效果实现原理及示例
2013/07/26 Javascript
jquery easyui 结合jsp简单展现table数据示例
2014/04/18 Javascript
使用js获取图片原始尺寸
2014/12/03 Javascript
NodeJS学习笔记之Connect中间件模块(一)
2015/01/27 NodeJs
jquery动态导航插件dynamicNav用法实例分析
2015/09/06 Javascript
JSONP和批量操作功能的实现方法
2016/08/21 Javascript
js print打印网页指定区域内容的简单实例
2016/11/01 Javascript
原生JS实现图片无缝滚动方法(附带封装的运动框架)
2017/10/01 Javascript
浅谈webpack对样式的处理
2018/01/05 Javascript
js实现unicode码字符串与utf8字节数据互转详解
2019/03/21 Javascript
微信小程序实现类似微信点击语音播放效果
2020/03/30 Javascript
解决layer.open弹出框不能获取input框的值为空的问题
2019/09/10 Javascript
OpenLayer学习之自定义测量控件
2020/09/28 Javascript
[06:42]DOTA2每周TOP10 精彩击杀集锦vol.1
2014/06/25 DOTA
[05:49]DOTA2-DPC中国联赛 正赛 Elephant vs LBZS 选手采访
2021/03/11 DOTA
利用Python爬虫给孩子起个好名字
2017/02/14 Python
python数据分析数据标准化及离散化详解
2018/02/26 Python
Python基于生成器迭代实现的八皇后问题示例
2018/05/23 Python
python数据处理 根据颜色对图片进行分类的方法
2018/12/08 Python
Python Pandas数据中对时间的操作
2019/07/30 Python
Python通过Manager方式实现多个无关联进程共享数据的实现
2019/11/07 Python
浅析Python3 pip换源问题
2020/01/06 Python
pycharm 中mark directory as exclude的用法详解
2020/02/14 Python
pytorch查看通道数 维数 尺寸大小方式
2020/05/26 Python
一款利用纯css3实现的超炫3D表单的实例教程
2014/12/01 HTML / CSS
写演讲稿所需要注意的4个条件
2014/01/09 职场文书
2014年技术工作总结范文
2014/11/20 职场文书
2016教师暑期培训学习心得体会
2016/01/09 职场文书
《乌鸦喝水》教学反思
2016/02/19 职场文书
创业者如何撰写出一份打动投资人的商业计划书?
2019/07/02 职场文书
Docker 镜像介绍以及commit相关操作
2022/04/13 Servers