2017-03-24 25 views
0

私は同じページで複数のフォームを使用しているサイトを持っています。私は私が実際に必要なコントロールだけを使用するようにカスタマイズした豊富なHTMLテキスト入力を、作成するために反応して 私はDraftjsを使用しています親からのdraftjs出力へのアクセス

class RichEditor extends React.Component { 
    constructor(props) { 
     super(props); 
     this.state = {editorState: EditorState.createEmpty()}; 

     this.focus =() => this.refs.editor.focus(); 
     this.onChange = (editorState) => { 
      this.setState({editorState}); 
     } 

     this.handleKeyCommand = (command) => this._handleKeyCommand(command); 
     this.onTab = (e) => this._onTab(e); 
     this.toggleBlockType = (type) => this._toggleBlockType(type); 
     this.toggleInlineStyle = (style) => this._toggleInlineStyle(style); 
    } 

    _handleKeyCommand(command) { 
     const {editorState} = this.state; 
     const newState = RichUtils.handleKeyCommand(editorState, command); 

     if (newState) { 
      this.onChange(newState); 
      return true; 
     } 
     return false; 
    } 

    _onTab(e) { 
     const maxDepth = 4; 
     this.onChange(RichUtils.onTab(e, this.state.editorState, maxDepth)); 
    } 

    _toggleBlockType(blockType) { 
     this.onChange(
      RichUtils.toggleBlockType(
       this.state.editorState, 
       blockType 
      ) 
     ); 
    } 

    _toggleInlineStyle(inlineStyle) { 
     this.onChange(
      RichUtils.toggleInlineStyle(
       this.state.editorState, 
       inlineStyle 
      ) 
     ); 
    } 

    render() { 
     const { editorState } = this.state; 

     let className = 'RichEditor-editor'; 
     var contentState = editorState.getCurrentContent(); 

     if (!contentState.hasText()) { 
      if (contentState.getBlockMap().first().getType() !== 'unstyled') { 
       className += ' RichEditor-hidePlaceholder'; 
      } 
     } 

     return (
      <div className="RichEditor-root"> 
       <BlockStyleControls 
        editorState={editorState} 
        onToggle={this.toggleBlockType} 
       /> 
       <InlineStyleControls 
        editorState={editorState} 
        onToggle={this.toggleInlineStyle} 
       /> 
       <div className={className} onClick={this.focus}> 
       <Editor 
        blockStyleFn={getBlockStyle} 
        customStyleMap={styleMap} 
        editorState={editorState} 
        handleKeyCommand={this.handleKeyCommand} 
        onChange={this.onChange} 
        onTab={this.onTab} 
        placeholder="" 
        ref="editor" 
        spellCheck={true} 
       /> 
       </div> 
      </div> 
     ); 
    } 
} 

module.exports = RichEditor 

私の親コンポーネントは次のようになります。

class WrapperComponent extends React.Component { 

    constructor(props) { 
     super(props); 
     this.onChange = (editorState2) => { 
      this.setState({editorState2}); 
      console.log("onChange"); 
      console.log(editorState2); 
     } 
     this.state = { 
      editorState1: EditorState.createEmpty(), 
      editorState2: EditorState.createEmpty(), 
      html: null 
     } 
    } 

    update() { 
     console.log("update"); 
     console.log(this.state.editorState2); 
     console.log(convertToRaw(this.state.editorState2.getCurrentContent())); 
     //this.setState({ draftEditor2: e.value }); 
     this.setState({ html: stateToHTML(this.state.editorState2.getCurrentContent()) }); 
    } 

    render() { 

     const Editable =() => (
      <div className="editor"> 
       <div className="editor-inner"> 
        <h3>Redigerar: Anbudsbrev</h3> 
        <h4>Rubrik</h4> 
        <input type="text" name="title" /> 
        <h4>Text 1</h4> 
        <RichEditor editorState={this.state.editorState1} updateStateToParent={this.onChange} name="text01" ref="editor" /> 
        <h4>Citat</h4> 
        <input type="text" name="quote01" /> 
        <h4>Text 2</h4> 
        <RichEditor updateStateToParent={this.onChange} name="text02" ref="editor" /> 
        <EditorFooter {...this.props} submitForm={this.submitForm} /> 
        <button onClick={this.update.bind(this)}>Update</button> 
        <div>{this.state.html}</div> 
       </div> 
      </div> 
     ); 

     const Readable =() => (
      <div> 
       <h1 className="header66">{this.props.title}</h1> 
       <div className="text66">{this.props.text01}</div> 
       <div className="quote100">{this.props.quote01}</div> 
       <div className="text66">{this.props.text02}</div> 
      </div> 
     ); 

     return (
      <div> 
       { this.props.isInEditMode ? <Editable /> : <Readable /> } 
      </div> 
     ); 
    } 
}; 

WrapperComponent.defaultProps = { 
    height: 100, 
    title: "Lorem ipsum dolor sit amet", 
    text01: "Mauris sollicitudin purus accumsan libero fringilla, vitae vulputate lorem aliquam. Nunc ipsum nisl, consectetur ac ultrices ac, pretium vitae lectus. Cras vestibulum, arcu non condimentum hendrerit, dolor ante molestie ante, eget dapibus felis quam a ante. Nunc fringilla risus eget nunc tincidunt sodales.", 
    quote01: "Aliquam erat volutpat.", 
    text02: "Praesent non erat quis sem mollis sodales. Integer convallis metus in ligula vehicula, quis vulputate lectus accumsan. Aliquam luctus posuere mollis. Aliquam luctus dignissim quam, ut aliquet ligula pellentesque ac. Nulla sodales lacus sem, eu pharetra arcu aliquet ac. Sed in venenatis libero." 
}; 

WrapperComponent.propTypes = { 
    content: PropTypes.object, 
    itemId: PropTypes.string 
} 

module.exports = WrapperComponent 

しかし、私何か基本的なことを誤解しているようだ。私はどちらの編集者からも価値を得ることができません。

私はRichEditorupdateStateToParentを送信する場合、私はいくつかのものが起こって見ることができますが、私はRichEditorから状態を取得し、WrapperComponentの状態にそれを追加することはできません。

私は間違った方法でこれに近づいていると思いますが、それを解決する方法について私の頭を得ることはできません。

答えて

1

あなたはここにはかなり近いと思いますが、問題は、親を使ってeditorStatesを設定していないことです。あなたは、親コンポーネントの内部にeditorStatesを格納して更新する必要があります。

  1. は、その内部の変化について親に知らせる小道具としてのeditorStateを受信し、親が順番に渡されますeditorStateを(更新しましょう:

    この

    RichEditor -componentがなければならないことを意味しますもう一度)。

ここでは、最小限の例です:

class RichEditor extends React.Component { 
    render() { 
     const { editorState, onChange } = this.props; 

     return (
      <div style={{ background: 'white' }}> 
      <Editor editorState={editorState} onChange={onChange} /> 
      </div> 
     ); 
    } 
} 

親はその順番でなければなりません:

  1. それらeditorsStatesを更新し、各RichEditorの初期editorStatesを作成します(そしてそれらを渡す)
  2. 変更するたびに

がここにいるの最小限の例です:https://jsfiddle.net/bwk32xuo/

class WrapperComponent extends React.Component { 
    constructor(props) { 
     super(props); 

     this.state = { 
      editorState1: EditorState.createEmpty(), 
      editorState2: EditorState.createEmpty() 
     } 
    } 

    onChange = (editorStateKey) => (editorState) => { 
     this.setState({ [editorStateKey]: editorState }); 
    } 

    render() { 
     return (
     <div> 
      <h4>Editor 1</h4> 
      <RichEditor editorState={this.state.editorState1} onChange={this.onChange('editorState1')} /> 
      <h4>Editor 2</h4> 
      <RichEditor editorState={this.state.editorState2} onChange={this.onChange('editorState2')} /> 
     </div> 
    ) 
    } 
}; 

そして最後に、ここでの作業フィドルです

関連する問題