reactjs 中使用百度Ueditor富文本編輯器

import React from 'react';
 
var Ueditor = React.createClass({ 
    componentDidMount(){
        var editor = UE.getEditor(this.props.id, {
             //工具欄
                toolbars: [[
                    'fullscreen', 'source', '|', 'undo', 'redo', '|',
                    'bold', 'italic', 'underline', 'fontborder', 'strikethrough', 'superscript', 'subscript', 'removeformat', 'formatmatch',  
                    '|', 'forecolor', 'backcolor', 'insertorderedlist', 'insertunorderedlist', 'selectall', 'cleardoc', '|',
                    'rowspacingtop', 'rowspacingbottom', 'lineheight', '|',
                    'customstyle', 'paragraph', 'fontfamily', 'fontsize', '|',
                    'directionalityltr', 'directionalityrtl', 'indent', '|',
                    'justifyleft', 'justifycenter', 'justifyright', 'justifyjustify', '|', 'touppercase', 'tolowercase', '|', 
                    'imagenone', 'imageleft', 'imageright', 'imagecenter', '|',
                    'simpleupload',  
                    'horizontal', 'date', 'time',  
                ]]
                ,lang:"zh-cn"
                //字體
                ,'fontfamily':[
                   { label:'',name:'songti',val:'宋體,SimSun'},
                   { label:'',name:'kaiti',val:'楷體,楷體_GB2312, SimKai'},
                   { label:'',name:'yahei',val:'微軟雅黑,Microsoft YaHei'},
                   { label:'',name:'heiti',val:'黑體, SimHei'},
                   { label:'',name:'lishu',val:'隸書, SimLi'},
                   { label:'',name:'andaleMono',val:'andale mono'},
                   { label:'',name:'arial',val:'arial, helvetica,sans-serif'},
                   { label:'',name:'arialBlack',val:'arial black,avant garde'},
                   { label:'',name:'comicSansMs',val:'comic sans ms'},
                   { label:'',name:'impact',val:'impact,chicago'},
                   { label:'',name:'timesNewRoman',val:'times new roman'}
                ]
                //字號
                ,'fontsize':[10, 11, 12, 14, 16, 18, 20, 24, 36]
                , enableAutoSave : false
                , autoHeightEnabled : false
                , initialFrameHeight: this.props.height
                , initialFrameWidth: '100%'
                ,readonly:this.props.disabled
        });
        var me = this;
        editor.ready( function( ueditor ) {
            var value = me.props.value?me.props.value:'<p></p>';
            editor.setContent(value); 
        }); 
    },
    render : function(){
        return (
             <script id={this.props.id} name="content" type="text/plain">
                  
             </script>
        )
    }
})
export default Ueditor;

上面是我寫的一個簡單富文本組件javascript

使用時就像通常表單同樣java

<Ueditor value={formData.content} id="content" height="200" disabled={!this.props.canEdit}/> 
// 入口頁面加載ueditor插件  
    <script type="text/javascript" src="/ueditor/ueditor.config.js"></script>
    <script type="text/javascript" src="/ueditor/ueditor.all.js"></script>
    <script type="text/javascript" src="/ueditor/lang/zh-cn/zh-cn.js"></script>
    

 

//獲取編輯器的內容
content = UE.getEditor("content").getContent();
//其餘
UE.getEditor("content").destroy();

  var dom = document.getElementById('content');
  if (dom) {
    dom.parentNode.removeChild(dom);
    }react


效果

相關文章
相關標籤/搜索