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加密解密7种方法总结分析
Oct 07 Javascript
Js实现双击鼠标自动滚动屏幕的示例代码
Dec 14 Javascript
Jquery中&quot;$(document).ready(function(){ })&quot;函数的使用详解
Dec 30 Javascript
按Enter键触发事件的jquery方法实现代码
Feb 17 Javascript
jQuery实现的表头固定效果实例【附完整demo源码下载】
Aug 01 Javascript
jQuery实现带延时功能的水平多级菜单效果【附demo源码下载】
Sep 21 Javascript
AngularJS开发教程之控制器之间的通信方法分析
Dec 25 Javascript
javascript实现电脑和手机版样式切换
Nov 10 Javascript
Electron-vue开发的客户端支付收款工具的实现
May 24 Javascript
vue 动态组件用法示例小结
Mar 06 Javascript
js实现表格单列按字母排序
Aug 12 Javascript
JS数组方法some、every和find的使用详情
Oct 05 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
JAVA/JSP学习系列之七
2006/10/09 PHP
简单采集了yahoo的一些数据
2007/02/14 PHP
解析在zend Farmework下如何创立一个FORM表单
2013/06/28 PHP
jQuery中的RadioButton,input,CheckBox取值赋值实现代码
2014/02/18 PHP
ThinkPHP模板输出display用法分析
2014/11/26 PHP
yii2实现根据时间搜索的方法
2016/05/25 PHP
PHP使用星号隐藏用户名,手机和邮箱的实现方法
2016/09/22 PHP
PHP实现留言板功能的详细代码
2017/03/25 PHP
PHP memcache在微信公众平台的应用方法示例
2017/09/13 PHP
通过JS自动隐藏手机浏览器的地址栏实现原理与代码
2013/01/02 Javascript
jquery easyui滚动条部分设置介绍
2013/09/12 Javascript
【经典源码收藏】jQuery实用代码片段(筛选,搜索,样式,清除默认值,多选等)
2016/06/07 Javascript
相册展示PhotoSwipe.js插件实现
2016/08/25 Javascript
浅谈angularjs module返回对象的坑(推荐)
2016/10/21 Javascript
微信小程序之数据双向绑定与数据操作
2017/05/12 Javascript
jquery之基本选择器practice(实例讲解)
2017/09/30 jQuery
Angular4自制一个市县二级联动组件示例
2017/11/21 Javascript
详解React服务端渲染从入门到精通
2019/03/28 Javascript
浅谈Python数据类型判断及列表脚本操作
2016/11/04 Python
Python实现定时任务
2017/02/08 Python
Python中list查询及所需时间计算操作示例
2018/06/21 Python
Ubuntu下Anaconda和Pycharm配置方法详解
2019/06/14 Python
python实现简单井字棋游戏
2020/03/04 Python
以实惠的价格提供高品质的时尚:Newchic
2018/01/18 全球购物
璀璨的珍珠、密钉和个性化珠宝:Lily & Roo
2021/01/21 全球购物
小学教师听课制度
2014/02/01 职场文书
元宵节晚会主持人串词
2014/03/25 职场文书
应届毕业生自荐信
2014/05/28 职场文书
企业法人代表授权委托书
2014/10/02 职场文书
公务员个人考察材料
2014/12/23 职场文书
检讨书格式
2015/01/23 职场文书
乡镇团委工作总结2015
2015/05/26 职场文书
2016春季校长开学典礼致辞
2015/11/26 职场文书
运动会班级口号霸气押韵
2015/12/24 职场文书
Oracle 区块链表创建过程详解
2021/05/15 Oracle
深入理解Pytorch微调torchvision模型
2021/11/11 Python