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 相关文章推荐
通过js来制作复选框的全选和不选效果
May 22 Javascript
基于jQuery 实现bootstrapValidator下的全局验证
Dec 07 Javascript
javascript实现简单的全选和反选功能
Jan 05 Javascript
js简单实现图片延迟加载的方法
Jul 19 Javascript
js实现加载更多功能实例
Oct 27 Javascript
jquery仿苹果的时间/日期选择效果
Mar 08 Javascript
jQuery+CSS实现的table表格行列转置功能示例
Jan 08 jQuery
JS文件中加载jquery.js的实例代码
May 05 jQuery
angular将html代码输出为内容的实例
Sep 30 Javascript
Node.js net模块功能及事件监听用法分析
Jan 05 Javascript
jQuery实现动态向上滚动
Dec 21 jQuery
分享15个Webpack实用的插件!!!
Mar 31 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
10条PHP高级技巧[修正版]
2011/08/02 PHP
基于AppServ,XAMPP,WAMP配置php.ini去掉警告信息(NOTICE)的方法详解
2013/05/07 PHP
Javascript图像处理—为矩阵添加常用方法
2012/12/27 Javascript
关于Javascript与iframe的那些事儿
2013/07/04 Javascript
javascript实现复制与粘贴操作实例
2014/10/16 Javascript
jquery实现textarea 高度自适应
2015/03/11 Javascript
简单的jQuery入门指引
2015/07/28 Javascript
JavaScript仿商城实现图片广告轮播实例代码
2016/02/06 Javascript
js实现页面a向页面b传参的方法
2016/05/29 Javascript
浅谈JavaScript 覆盖原型以及更改原型
2016/08/31 Javascript
Bootstrap CSS组件之面包屑导航(breadcrumb)
2016/12/17 Javascript
nodejs mysql 实现分页的方法
2017/06/06 NodeJs
Angular 4.X开发实践中的踩坑小结
2017/07/04 Javascript
Vue 与 Vuex 的第一次接触遇到的坑
2018/08/16 Javascript
微信小程序中this.data与this.setData的区别详解
2018/09/17 Javascript
使用jQuery动态设置单选框的选中效果
2018/12/06 jQuery
JavaScript中的类型检查
2020/02/03 Javascript
jquery实现加载更多&quot;转圈圈&quot;效果(示例代码)
2020/11/09 jQuery
介绍Python的Urllib库的一些高级用法
2015/04/30 Python
Python中title()方法的使用简介
2015/05/20 Python
MySQL中表的复制以及大型数据表的备份教程
2015/11/25 Python
python使用json序列化datetime类型实例解析
2018/02/11 Python
python实现自动发送邮件
2018/06/20 Python
Python基础教程之if判断,while循环,循环嵌套
2019/04/25 Python
Python 二叉树的层序建立与三种遍历实现详解
2019/07/29 Python
python turtle工具绘制四叶草的实例分享
2020/02/14 Python
python 使用paramiko模块进行封装,远程操作linux主机的示例代码
2020/12/03 Python
英国屋顶用品和材料超市:Roofing Supplies UK
2019/08/24 全球购物
俄罗斯最大的隐形眼镜销售网站:Ochkov.Net
2021/02/07 全球购物
酷瑞网络科技面试题
2012/03/30 面试题
中间件分为哪几类
2016/09/18 面试题
采购部经理岗位职责
2014/02/10 职场文书
食品安全责任书
2014/04/15 职场文书
大学生就业自荐书
2014/06/16 职场文书
缅怀先烈主题班会
2015/08/14 职场文书
Python安装及建立虚拟环境的完整步骤
2022/06/25 Servers