react中使用echarts和富文本

富文本.png
import React, { Component } from 'react'




// 引入 ECharts 主模塊
import echarts from 'echarts/lib/echarts';
// 引入柱狀圖
import 'echarts/lib/chart/bar';
import 'echarts/lib/chart/pie';

// 引入提示框和標(biāo)題組件
import 'echarts/lib/component/tooltip';
import 'echarts/lib/component/title';

//  富文本
import E from 'wangeditor'





class power extends Component {
    constructor(props) {
        super(props);
        this.state = {
            collapsed: true,
            // 富文本
            editorContent: "<div>默認值</div>"

        }
    }
    render() {
        return (

            <div>
                    <p> 富文本的相關(guān)引用  </p>
              
            {/* <div id="main" style={{ width: "100%", height: "600px" }}></div> */}
                {/* <div id="pie" style={{ width: "600px", height: "400px" }}></div> */}

                {/*  富文本  */}
                <div className="shop">
                    <div className="text-area" >
                        <div ref="editorElemMenu"
                            style={{ backgroundColor: '#f1f1f1', border: "1px solid #ccc" }}
                            className="editorElem-menu">

                        </div>
                        <div
                            style={{
                                padding: "0 10px",
                                overflowY: "hidden",
                                height: 600,
                                border: "1px solid #ccc",
                                borderTop: "none"
                            }}
                            ref="editorElemBody" className="editorElem-body">

                        </div>
                    </div>
                </div>


            </div>

        )
    }
    componentDidMount() {

        // 基于準(zhǔn)備好的dom敬惦,初始化echarts實例
        // var myChart = echarts.init(document.getElementById('main'));
        // // 繪制圖表
        // myChart.setOption({
        //     title: { text: "柱形圖" },
        //     tooltip: {},
        //     xAxis: {
        //         data: ["襯衫", "羊毛衫", "雪紡衫", "褲子", "高跟鞋", "襪子"]
        //     },
        //     yAxis: {},
        //     series: [{
        //         name: '銷量',
        //         type: 'bar',
        //         data: [5, 20, 36, 10, 10, 20]
        //     }]
        // });


        //  富文本
        const elemMenu = this.refs.editorElemMenu;
        const elemBody = this.refs.editorElemBody;
        const editor = new E(elemMenu,elemBody)
        // 使用 onchange 函數(shù)監(jiān)聽內(nèi)容的變化邻耕,并實時更新到 state 中
        editor.customConfig.onchange = html => {
            console.log(editor.txt.html())
            this.setState({
                // editorContent: editor.txt.text()
                editorContent: editor.txt.html()
            })
        }
        editor.customConfig.menus = [
            'head',  // 標(biāo)題
            'bold',  // 粗體
            'fontSize',  // 字號
            'fontName',  // 字體
            'italic',  // 斜體
            'underline',  // 下劃線
            'strikeThrough',  // 刪除線
            'foreColor',  // 文字顏色
            'backColor',  // 背景顏色
            'link',  // 插入鏈接
            'list',  // 列表
            'justify',  // 對齊方式
            'quote',  // 引用
            'emoticon',  // 表情
            'image',  // 插入圖片
            'table',  // 表格
            'video',  // 插入視頻
            'code',  // 插入代碼
            'undo',  // 撤銷
            'redo'  // 重復(fù)
        ]
        editor.customConfig.uploadImgShowBase64 = true
        editor.customConfig.uploadImgServer = '/upload';  // 上傳圖片到服務(wù)器
        // 3M
        editor.customConfig.uploadImgMaxSize = 3 * 1024 * 1024;
        // 限制一次最多上傳 5 張圖片
        editor.customConfig.uploadImgMaxLength = 1;
        // 自定義文件名
        editor.customConfig.uploadFileName = 'editor_img';
        // 將 timeout 時間改為 3s
        editor.customConfig.uploadImgTimeout = 5000;
    
        editor.customConfig.uploadImgHooks = {
            before: function (xhr, editor, files) {
                // 圖片上傳之前觸發(fā)
                // xhr 是 XMLHttpRequst 對象磁玉,editor 是編輯器對象身冬,files 是選擇的圖片文件
    
                // 如果返回的結(jié)果是 {prevent: true, msg: 'xxxx'} 則表示用戶放棄上傳
                // return {
                //     prevent: true,
                //     msg: '放棄上傳'
                // }
                // alert("前奏");
            },
            success: function (xhr, editor, result) {
                // 圖片上傳并返回結(jié)果葵陵,圖片插入成功之后觸發(fā)
                // xhr 是 XMLHttpRequst 對象纸型,editor 是編輯器對象,result 是服務(wù)器端返回的結(jié)果
                // var url = result.data.url;
                // alert(JSON.stringify(url));
                // editor.txt.append(url);
                // alert("成功");
            },
            fail: function (xhr, editor, result) {
                // 圖片上傳并返回結(jié)果食铐,但圖片插入錯誤時觸發(fā)
                // xhr 是 XMLHttpRequst 對象匕垫,editor 是編輯器對象,result 是服務(wù)器端返回的結(jié)果
                alert("失敗");
            },
            error: function (xhr, editor) {
                // 圖片上傳出錯時觸發(fā)
                // xhr 是 XMLHttpRequst 對象璃岳,editor 是編輯器對象
                // alert("錯誤");
            },
            // 如果服務(wù)器端返回的不是 {errno:0, data: [...]} 這種格式年缎,可使用該配置
            // (但是,服務(wù)器端返回的必須是一個 JSON 格式字符串A蹇丁5ノ摺!否則會報錯)
            customInsert: function (insertImg, result, editor) {
                // 圖片上傳并返回結(jié)果犁柜,自定義插入圖片的事件(而不是編輯器自動插入圖片V摒!2雒濉)
                // insertImg 是插入圖片的函數(shù)扒腕,editor 是編輯器對象,result 是服務(wù)器端返回的結(jié)果
                // 舉例:假如上傳圖片成功后萤悴,服務(wù)器端返回的是 {url:'....'} 這種格式瘾腰,即可這樣插入圖片:
                var url = result.data[0];
                insertImg(url);
                // result 必須是一個 JSON 格式字符串!8猜摹蹋盆!否則報錯
            }
        }

        editor.create();
        //  富文本回顯  比如后后臺請求的接口數(shù)據(jù)  用于渲染頁面
   
        editor.txt.html( this.state.editorContent );



    }

 

}
export default power;

默認的富文本怎么顯示?

editorContent  就是默認的數(shù)據(jù)
 editor.txt.html( this.state.editorContent );
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末硝全,一起剝皮案震驚了整個濱河市栖雾,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌伟众,老刑警劉巖析藕,帶你破解...
    沈念sama閱讀 221,695評論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異凳厢,居然都是意外死亡账胧,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評論 3 399
  • 文/潘曉璐 我一進店門数初,熙熙樓的掌柜王于貴愁眉苦臉地迎上來找爱,“玉大人,你說我怎么就攤上這事泡孩〕瞪悖” “怎么了?”我有些...
    開封第一講書人閱讀 168,130評論 0 360
  • 文/不壞的土叔 我叫張陵仑鸥,是天一觀的道長吮播。 經(jīng)常有香客問我,道長眼俊,這世上最難降的妖魔是什么意狠? 我笑而不...
    開封第一講書人閱讀 59,648評論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮疮胖,結(jié)果婚禮上环戈,老公的妹妹穿的比我還像新娘闷板。我一直安慰自己,他們只是感情好院塞,可當(dāng)我...
    茶點故事閱讀 68,655評論 6 397
  • 文/花漫 我一把揭開白布遮晚。 她就那樣靜靜地躺著,像睡著了一般拦止。 火紅的嫁衣襯著肌膚如雪县遣。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,268評論 1 309
  • 那天汹族,我揣著相機與錄音萧求,去河邊找鬼。 笑死顶瞒,一個胖子當(dāng)著我的面吹牛夸政,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播搁拙,決...
    沈念sama閱讀 40,835評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼秒梳,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了箕速?” 一聲冷哼從身側(cè)響起酪碘,我...
    開封第一講書人閱讀 39,740評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎盐茎,沒想到半個月后兴垦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,286評論 1 318
  • 正文 獨居荒郊野嶺守林人離奇死亡字柠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,375評論 3 340
  • 正文 我和宋清朗相戀三年探越,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片窑业。...
    茶點故事閱讀 40,505評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡钦幔,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出常柄,到底是詐尸還是另有隱情鲤氢,我是刑警寧澤,帶...
    沈念sama閱讀 36,185評論 5 350
  • 正文 年R本政府宣布西潘,位于F島的核電站卷玉,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏喷市。R本人自食惡果不足惜相种,卻給世界環(huán)境...
    茶點故事閱讀 41,873評論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望品姓。 院中可真熱鬧寝并,春花似錦箫措、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至别渔,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間惧互,已是汗流浹背哎媚。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留喊儡,地道東北人拨与。 一個月前我還...
    沈念sama閱讀 48,921評論 3 376
  • 正文 我出身青樓,卻偏偏與公主長得像艾猜,于是被迫代替她去往敵國和親买喧。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,515評論 2 359