Giter Club home page Giter Club logo

re-editor's Introduction

re-editor · Netlify Status CircleCI npm GitHub license code style: prettier

一个开箱即用的React富文本编辑器 🚀

image

特点

  • 开箱即用,无需配置
  • 定制化,可自行开发任意风格和形式的工具条 [API补全中]
  • 支持元素功能设置,例如修改图片大小
  • 支持markdown语法
  • 查看更多

使用方法

编辑器为适应不同开发需求,提供下面两种使用方法

开箱即用

re-editor是一个封装好的组件, 安装就可以使用, 它里面包含 @re-editor/core@re-editor/toolbar-antd, 工具条默认使用antd风格,如果要使用其他工具条请参考下面自定义文档

安装依赖

$ npm install re-editor

引入样式

在js里面引入

import 're-editor/lib/styles/index.css'

也可以在css里面引入(需要css预处理支持)

@import 're-editor/lib/styles/index.css'

props

属性 说明 类型
value 编辑器的值 object
onChange 编辑器更改内容的回调 (value: Value) => void
placeholder 占位文本 string
readOnly 只读模式 boolean
onImageUpload 自定义图床 (file: File) => Promise<url: string>
tools 设置工具栏的显示内容 Array<Array

设置工具栏显示内容

tools props支持数组形式,如果是二维数组会分组显示

tools={['bold', 'italic', 'underline', 'strikethrough']}
// 或者
tools={[
  ['bold', 'italic', 'underline', 'strikethrough'],
  ['orderedlist', 'unorderedlist']
]}
名称 功能
bold 粗体
italic 斜体
underline 下划线
strikethrough 删除线
orderedlist 有序列表
unorderedlist 无序列表
heading 标题
align 对齐方式
image 图片
table 表格
code 代码
undo 撤销
redo 重做
fullscreen 全屏

自定义

编辑器拆分为两个部分,内容编辑区域 和 工具条,下面介绍如何自定义工具条

安装编辑器核心

$ npm install @re-editor/core

创建工具条

可以用任何方式创建编辑器工具条,需要将编辑器的实例传给工具条,可参考 re-editor@re-editor/toolbar-antd的实现,详情查看API文档(这部分文档还没写完,会在近期补全😂)

例如实现一个加粗功能:

import { command } from '@re-editor/core';

const Demo = (props) => {
  function handleClick() {
    command(props.editor)('bold')
  }
  return <div onClick={handleClick}>bold</div>
}

packages介绍

  • re-editor: 一个封装好的,包含工具条的编辑器
  • @re-editor/core: 编辑器核心
  • @re-editor/toolbar-antd: 基于antd制作的工具条,默认
  • @re-editor/examples: 演示项目

FAQ

和slate或draft-js对比有什么区别?

slate或draft并不是一个纯编辑器,它们更像是一个用于构建编辑器的框架,re-editor是基于slate开发,让你不必关注构建编辑器的过程。

怎么修改样式

样式分为两部分,node(粗体、h1、h2等)和工具栏,它们都可以通过css重写基础样式,工具栏也可以做到完全重写 样式可以通过css自定义

每次保存数据量太大怎么办?

使用增量更新,onChange回调的value是 immutable格式,可以使用immutable-js-diff等方法获取diff的内容进行增量更新

如何指定上传图片服务器

图片默认保存为base64,如果需要将图片上传到指定服务器,可使用onImageUpload函数, (file: File) => Promise<url: string> 示例代码

功能

文字装饰

粗体 斜体 下划线 删除线 上标 下标

列表

有序列表 无序列表

对齐方式

左对齐 右对齐 居中对齐 两端对齐

标题

h1 h2 h3 h4 h5 h6

其他

  • 图片
    • 设置大小
    • 从剪贴板复制
    • 支持自定义上传图片服务器地址
  • 表格
    • 增加行
    • 增加列
    • 删除行
    • 删除列
  • 代码高亮
    • js
    • css
    • html
  • markdown
    • h1-h6: #
    • 引用: >
    • 有序列表: -
    • 无序列表: 1.
  • 全屏编辑

其他功能持续增加中...

re-editor's People

Contributors

dependabot-preview[bot] avatar wowlusitong avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar

re-editor's Issues

REACT HOOKS下从后端获取文本后没办法渲染?

异步从后端获取文本后不能够成功渲染,文本框始终是空的

export const Editor = () => {
    const [value, setValue] = useState(null);
   
    useEffect(() => {
        httpRequest("get", api.NoticeManage).then(response=>{
            setValue(JSON.parse(response.data.text))
        })
    }, [])
    
    const handleChange = (value) => {
        setValue(JSON.stringify(value.toJS()))
    }
    return (
        <ReEditor
            value={value}
            onChange={handleChange}
            placeholder="请输入内容"
            // onImageUpload={this.handleImageUpload}
        />
    )
}

期望工具补充

1.支持超链接
2.支持附件上传
3.支持自定义图标及对应的回调,比如添加保存图标后自定义函数响应中做持久化

new features request

图片:
1 建议图片初始按原图长宽比显示
2 图片用鼠标拉动缩放时,不要用角标拉(做得不够好),可以改成单纯拉高度和单纯拉宽度结合的方式
3 甚至进一步,用第三方 ‘react-image-crop’ 来弹出框,可以裁剪和旋转原图,截取选中部分来做结果图

保存和显示:
用json格式保存内容挺好,需要加一个显示结果的css或者独立react小组件,用来在需要显示结果的地方用来显示这个json内容。(用re-editor的只读模式可以做到,是不是可以更小巧些?)

建议将 ImageUploader 组件的 handleFileUpload 方法 暴露为一个接口

现在处理 image-local 的方式是直接把图片转为Base64插入到内容里,这样会导致数据很大。

实际使用中我们可能会希望把图片上传到一个图片服务器,然后再通过一个地址来引用。
但是我看了一下源码,发现好像并没有提供相应的接口来定制上传文件的过程。

虽然我可以自己封装一个组件实现upload 的过程,然后把返回的地址通过command(editor)('image',src)的方式插入到内容里。但是图片的替换功能依然写死了是调用 image-local 的。

我觉得比较好的方式,是将 ImageUploader 组件的 handleFileUpload 方法暴露为一个接口。这样可以比较灵活的实现定制的上传过程。

引入报错

TypeError: _icon.default.createFromIconfontCN is not a function

var _icon = _interopRequireDefault(require("antd/es/icon"));

var _default = _icon.default.createFromIconfontCN({
scriptUrl: '//at.alicdn.com/t/font_1089062_pnt5z551qz.js'
});

图片尺寸设置有问题

目前在DEMO里上传一个图片,尺寸变形(宽度全宽高度不是按比例缩放),手工设置高宽时,高宽的输入框似乎不能获得焦点。

另外看看是否可能鼠标拉动缩放图片?

我的操作环境:MACOS + CHROME

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.