在react项目中,富文本编辑器的使用

react 编辑器的选择

说到富文本编辑器那可是一箩筐,数不胜数。国内比较知名的百度编辑器首当其冲。外国吗?Simditor很比错,功能精简、加载速度快速,但是没有react版的,要想使用就手动封装吧。对于react的富文本编辑器还没一个定论,我是说还没有一个纯react封装的富文本编辑器被大家广为使用,也许是坑太大了,没人能很好的填上。

也不是没有人填,facebook就出一款react富文本编辑器叫draft-js,可以说它的界面精简至极,缺点是没有继承上传图片这等功能,对于这种要编辑长文的编辑器然要有解决办法,medium-draft集成上传图片,添加了更加丰富的功能,不过它的设计和交互,在国内用户习惯和思维还没那么前卫的情况,尽量不要选用。或者你能力够强,去码源码。

根据项目需求我们希望使用百度编辑器那样丰富的功能和简洁的设计,在github找到了react-umeditor,这是liuhong1happy同学将百度富文本编辑器用react封装的一个组件。查看了react-umeditor的demo,对该编辑器多方面评估,满足我们的项目需求,接下来就是在项目中尝试使用它了。

使用react-umeditor富文本编辑器

Install
npm install react-umeditor --save
Use

javascript

import React from 'react'
import ReactDOM from 'react-dom'
import Editor from 'react-umeditor'

class App extends React.Component {
    constructor(props){
        super(props);
        this.state = {
            content: ""
        }
    }
    handleChange(content){
        this.setState({
            content: content
        })
    }
    getIcons(){
        var icons = [
            "source | undo redo | bold italic underline strikethrough fontborder emphasis | ",
            "paragraph fontfamily fontsize | superscript subscript | ",
            "forecolor backcolor | removeformat | insertorderedlist insertunorderedlist | selectall | ",
            "cleardoc  | indent outdent | justifyleft justifycenter justifyright | touppercase tolowercase | ",
            "horizontal date time  | image emotion spechars | inserttable"
        ]
        return icons;
    }
    getQiniuUploader(){
        return {
            url:'http://upload.qiniu.com',
            type:'qiniu',
            name:"file",
            request: "image_src",
            qiniu:{
                app:{
                    Bucket:"liuhong1happy",
                    AK:"l9vEBNTqrz7H03S-SC0qxNWmf0K8amqP6MeYHNni",
                    SK:"eizTTxuA0Kq1YSe2SRdOexJ-tjwGpRnzztsSrLKj"
                },
                domain:"http://o9sa2vijj.bkt.clouddn.com",
                genKey:function(options){
                    return options.file.type +"-"+ options.file.size +"-"+ options.file.lastModifiedDate.valueOf() +"-"+ new Date().valueOf()+"-"+options.file.name;
                }
            }
        }
    }
    render(){
        var icons = this.getIcons();
        var uploader = this.getQiniuUploader();
        var plugins = {
            image:{
                uploader:uploader
            }
        }
        var count = 100;
        var editors = [];
        for(var i=0;i<count;i++){
            editors.push({
                icons:icons,
                plugins:plugins
            })
        }
        return (<Editor ref="editor"
                                icons={icons}
                                value={this.state.content}
                                defaultValue="<p>提示文本</p>"
                                onChange={this.handleChange.bind(this)}
                                plugins={plugins} />)
    }
}

html

<!doctype html>
<html lang="zh-CN">
<head>
    <meta charset="utf-8">
    <title>首页</title>
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta http-equiv="Cache-Control" content="no-siteapp">
    <!-- 引入富文本编辑器的样式 -->
    <link rel="stylesheet" href="../../dist/third-part/mathquill/mathquill.css"/>
    <link rel="stylesheet" href="app.css" type="text/css" />
    <!-- 引入富文本编辑器的样式 -->
</head>
<body>
    <div id="root"></div>
    <!-- 引入富文本编辑器的js -->
    <script src="../../dist/third-part/jquery.min.js"></script>
    <script src="../../dist/third-part/mathquill/mathquill.js"></script>
    <!-- 引入富文本编辑器的js -->
    <script src='assets/dist/js/lib.js'></script>
    <script src='assets/dist/js/index.js'></script>
</body>
</html>

images(图标icons)

需要把images和third-part文件夹放到项目里

package.json(配置)

"copy": "cp -R images/. dist/images && cp -R less/. dist/less && cp -R third-part/. dist/third-part",

最终效果

富文本编辑器.jpeg

小结

期间对多个富文本编辑器在项目调试,最终选择了liuhong的react-umeditor,在组件使用过程中出现了很多问题。像图标引入不到项目里、需要修改配置等问题,最后都一一解决了。最后提示自己只看没用,一定要多实践,实践出真理,实践出真理,实践出真理,重要的事情说三遍。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,830评论 5 468
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,992评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,875评论 0 331
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,837评论 1 271
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,734评论 5 360
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,091评论 1 277
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,550评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,217评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,368评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,298评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,350评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,027评论 3 315
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,623评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,706评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,940评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,349评论 2 346
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,936评论 2 341

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,271评论 25 707
  • Draft.js是Facebook开源的开发React富文本编辑器开发框架。和其它富文本编辑器不同,draft.j...
    MarxJiao阅读 14,486评论 0 13
  • 我们每个人的大脑,都内嵌着一个“自我保护机制”,它以各式各样的方式尽量去保证自己不会产生“心理崩溃”。吐槽抱怨,嫉...
    YvanTalk阅读 366评论 1 1
  • 这个星期,连续多天,超过夜晚十二点仍毫无睡意,心里很清楚,“我很困,很累,还有明天还满课呢,快睡,不然明天课没法上...
    沫什真阅读 286评论 1 2
  • 我之国,大理城 你的皮肤烧着没 身着青衫的人哪 呼吸的全是汗水 你那甘甜的乳水 我从何处可品尝 你那阳春的白雪 叫...
    小鱼clover阅读 154评论 0 4