# 富文本及 Markdown 编辑器 基于 [braft-editor](https://github.com/margox/braft-editor) 和 [react-mde](https://github.com/andrerpena/react-mde) 的富文本编辑器。 ## install ``` $ npm install git+https://git.links123.net/node/editor.git --save # or $ yarn add git+https://git.links123.net/node/editor.git ``` ## 使用 #### RichEditor ```js import React from 'react' import { RichEditor } from 'editor'; const { EditorState } = RichEditor; export default class RichEditorDemo extends React.Component { state = { // 创建一个空的editorState作为初始值 editorState: EditorState.createFrom('') } async componentDidMount () { // 假设此处从服务端获取html格式的编辑器内容 const htmlContent = await fetchEditorContent() const htmlContent = '

ss

' // 使用EditorState.createFrom将html字符串转换为编辑器需要的editorState数据 this.setState({ editorState: EditorState.createFrom(htmlContent) }) } submitContent = async () => { // 在编辑器获得焦点时按下ctrl+s会执行此方法 // 编辑器内容提交到服务端之前,可直接调用editorState.toHTML()来获取HTML格式的内容 const htmlContent = this.state.editorState.toHTML() const result = await saveEditorContent(htmlContent) } handleEditorChange = (editorState) => { this.setState({ editorState }) } render () { const { editorState } = this.state return (
) } } ``` - defaultProps: |props|type|value| |:-:|:-:|:-:| |controls|array|| ```js const controls = [ 'headings', 'text-color', 'bold', 'italic', 'underline', 'strike-through', 'separator', 'superscript', 'subscript', 'remove-styles', 'emoji', 'text-align', 'separator', 'list-ul', 'list-ol', 'blockquote', 'code', 'separator', 'link', 'separator', 'hr', 'separator', 'media', 'separator', 'undo', 'redo' ] ``` #### MarkdownEditor ```js import React from "react"; import { MarkdownEditor } from 'editor'; export default class MarkdownEditorDemo extends React.Component { constructor(props) { super(props); this.state = { mdeState: null, }; this.converter = new Showdown.Converter({tables: true, simplifiedAutoLink: true}); } handleValueChange = (mdeState) => { this.setState({mdeState}); } render() { return ( ); } } ``` - default props: |props|type|value| |:-:|:-:|:-:| |layout|string|'horizontal'| |buttonContentOptions|object|| |generateMarkdownPreview|func|| ```js const icons = { "bold": , "heading": , "italic": , "strikethrough": , "link": , "quote-right": , "code": , "image": , "list-ul": , "list-ol": , "tasks": , }; const iconProvider = (name) => { return icons[name] || "❓"; }; const defaultProps = { layout: 'horizontal', buttonContentOptions: { iconProvider }, generateMarkdownPreview: (markdown) => Promise.resolve(this.converter.makeHtml(markdown)), } ```