Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

ifanrx-react-ueditor-fix

ifanrx2MIT2.3.0

an ueditor component for react

ueditor, react

readme

react-ueditor

react-ueditor

使用 react 框架对 ueditor 进行封装和扩展

✨ 特性

  • 支持更灵活的图片和音视频资源上传
  • 支持同个页面存在多个编辑器实例
  • 支持对复制进来的图片进行操作
  • 允许扩展工具栏,支持在扩展中使用已有的 react 组件

📦 下载

# 使用 npm 安装
npm install ifanrx-react-ueditor --save

# 使用 yarn 安装
yarn add ifanrx-react-ueditor

🔨 使用

import ReactUeditor from 'ifanrx-react-ueditor'

<ReactUeditor
  ueditorPath={`${window.YOUR_PATH}/ueditor`}"
/>

🔌 插件

extendControls 已不推荐使用,请直接使用 plugins,指定插件。

插件分为两种,一种是内置的插件,一种是自定义的插件。现支持内置插件如下:

  1. insertCode 插入代码块
  2. uploadImage 上传图片
  3. uploadVideo 上传视频
  4. uploadAudio 上传音频
  5. insertLink 添加链接

内置插件,直接传入插件的名称即可。自定义插件则是传入一个 Function,类型定义(使用 typescript 只为了说明类型)为:

interface IPlugin {
  (ueditor: UEditor): IPluginConfig
}

interface IPluginConfig {
  cssRules: String
  menuText: String
  onIconClick?: () => void
  render: (visible: Boolean, closeModal: () => void) => React.ReactElement<any>
  title?: String
}

UEditor 为 UEditor 实例。详细内容,请参考官方文档

插件使用示例

  1. 内置插件

     <ReactUeditor
       ...
       plugins={[
         'insertCode',
         'uploadImage',
         'uploadVideo',
         'uploadAudio',
         'insertLink',
       ]}
       ...
     />
  2. 自定义插件

     const uploadImagePlugin = ueditor => {
       return {
         menuText: '图片上传',
         cssRules: 'background-position: -726px -77px;',
         render: (visible, closeModal) => {
           const handleSelectImage = (url) => {
             ueditor.focus()
             ueditor.execCommand('inserthtml', `<img src="${url}" />`)
             closeModal()
           }
           return <Modal visible={visible} onSelectImage={handleSelectImage} />
         }
       }
     }
    
     <ReactUeditor
       ...
       plugins={[uploadImagePlugin]}
       ...
     />

更多功能请移步到 react-ueditor 的 wiki 页面

🤝 贡献


kailunyao

larry011

PRs Welcome

如果你希望为这个项目贡献代码,需要了解以下情况:

  • 在根目录下执行 yarn start 会启动开发服务器,此时会在浏览器中展示 ReactUeditor 的真实效果,在 ReactUeditor/ 下的修改都会进行热更新

  • example.js, index.html, dist/ 都只是为了展示 ReactUeditor 的真实效果,主要代码在 ReactUeditor/ 中

  • 需要修改 ueditor 源码时,直接修改 ueditor 目录下的文件,修改完执行:cd ueditoryarn grunt 命令,此时会重新生成 ueditor 构建成功的文件到 vendor/ueditor

changelog

v2.3.0 (2019-04-28)

  • [M] 修改自定义插件实现

v2.2.0 (2019-01-10)

  • [A] 通过 pasteImageStart 和 pasteImageDone 方法,暴露当前粘贴图片的进度

v2.1.0 (2019-01-07)

  • [A] extendControls 模态框支持配置 zIndex 和垂直居中方式(top 和 middle)

v2.0.0 (2019-01-04)

  • [A] 允许对复制进来的图片进行操作
  • [A] 允许通过 extendControls 属性在工具栏添加自定义功能(以弹出模态框的方式)
  • [F] 修复存在多实例时,工具栏样式不更新
  • [F] 修复少数情况下,ueditor 自身的报错
  • [C] 完善文档和补充更多示例

v1.7.0(2018-12-03)

  • [A] 暴露 ueditor 加载完成事件 onReady

v1.6.0(2018-12-03)

  • [C] 更新到 babel 7 和 webpack 4

v1.5.3(2018-10-30)

  • [A] Resolve #16 Fix error that id is not defind when click the link icon

v1.5.2(2018-10-19)

  • [A] Resolve #16 Fix unexpected use of 'location' no-restricted-globals

v1.5.1(2018-08-17)

  • [A] 修复在 Safari 导致视频无法删除,无法将光标移动到视频后面的 bug

v1.5.0(2018-07-27)

  • [A] 支持多图片上传 multipleImagesUpload

v1.4.2(2018-07-14)

  • [C] 更新 package.json 并发布到 npm

v1.4.1(2018-07-06)

  • [F] 修复多个实例时,图片,视频,音频插入错误的问题

v1.4.0(2018-07-05)

  • [A] 添加获取 ueditor 实例接口 gerRef
  • [F] 修复插入表情不触发 onChange 事件

v1.3.0 (2017-11-20)

  • [A] 针对多个编辑器实例而配置有所差异的场景,添加 config 属性
  • [A] 添加用于视频和音频上传进度展示的 progress 属性
  • [A] 代码添加 eslint
  • [F] 修复控制台报 get property 'scrollTo' from undefined 错误

v1.2.0 (2017-11-16)

  • [M] 修改图片上传后回调插入图片的方式
  • [A] 添加视频和音频的上传和插入接口

v1.1.0 (2017-10-16)

  • [A] 添加 plugins 属性用于配置所需插件
  • [A] 添加 insertCode 插件,用于简单地插入代码片段