簡體   English   中英

如何使用draft.js 插入圖像?

[英]How to insert an image using draft.js?

這是我嘗試在 Draft.js 編輯器中插入圖像的代碼。 但我失敗了。 當我點擊按鈕時,只插入了幾行空行,有什么問題?

我的編輯器

import React from 'react';
import {Editor, EditorState, AtomicBlockUtils} from 'draft-js';

export class MyEditor extends React.Component {

  constructor(props) {
    super(props);
    this.state = {editorState: EditorState.createEmpty()};
    this.onChange = (editorState) => this.setState({editorState});
  }

  render() {
    return (
      <div>
        <Editor editorState={this.state.editorState} onChange={this.onChange}/>
        <button onClick={this.handleClick}>Insert an image</button>
      </div>
    );
  }

  handleClick = () => {
    const base64 = "";
    const newEditorState = this.insertImage(this.state.editorState, base64);
    this.onChange(newEditorState);
  };

  insertImage = (editorState, base64) => {
    const contentState = editorState.getCurrentContent();
    const contentStateWithEntity = contentState.createEntity(
      'image',
      'IMMUTABLE',
      { src: base64 },
    );
    const entityKey = contentStateWithEntity.getLastCreatedEntityKey();
    const newEditorState = EditorState.set(
      editorState,
      { currentContent: contentStateWithEntity },
    );
    return AtomicBlockUtils.insertAtomicBlock(newEditorState, entityKey, ' ');
  };

}

應用程序.js

class App extends Component {
  render() {
    return (
      <MyEditor/>
    );
  }
}

export default App;

結果

在此處輸入圖片說明

對於圖像支持,您應該使用draft-js圖像插件,例如draft-js-image-plugin: https//www.draft-js-plugins.com/plugin/image

默認情況下,draft-js不支持插件,因此最好使用draft-js-plugins-editor,它擴展了draft-js的功能。

所以你的代碼是:

 import React from "react"; import { convertToRaw, EditorState, AtomicBlockUtils } from "draft-js"; import Editor from "draft-js-plugins-editor"; import createImagePlugin from "draft-js-image-plugin"; const imagePlugin = createImagePlugin(); const plugins = [imagePlugin]; export default class MyEditor extends React.Component { constructor(props) { super(props); this.state = { editorState: EditorState.createEmpty() }; this.onChange = editorState => this.setState({ editorState }); } render() { return ( <div> <Editor editorState={this.state.editorState} onChange={this.onChange} plugins={plugins} ref={element => { this.editor = element; }} /> <button onClick={this.handleClick}>Insert an image</button> <pre> {JSON.stringify( convertToRaw(this.state.editorState.getCurrentContent()), null, " " )} </pre> </div> ); } handleClick = () => { const base64 = ""; const newEditorState = this.insertImage(this.state.editorState, base64); this.onChange(newEditorState); }; insertImage = (editorState, base64) => { const contentState = editorState.getCurrentContent(); const contentStateWithEntity = contentState.createEntity( "image", "IMMUTABLE", { src: base64 } ); const entityKey = contentStateWithEntity.getLastCreatedEntityKey(); const newEditorState = EditorState.set(editorState, { currentContent: contentStateWithEntity }); return AtomicBlockUtils.insertAtomicBlock(newEditorState, entityKey, " "); }; } 

draft-js-image-plugin的最新版本有錯誤,因此您可以使用2.0.1版本。

我正在使用最新的draft-js版本"draft-js": "0.10.5", "draft-js-image-plugin": "2.0.1","draft-js-plugins-editor": "2.0.3",

您可以在沒有插件的情況下添加圖像,請參閱名為“媒體”的官方演示

它使用了draft-js Editor組件的blockRendererFn屬性。

const Image = (props) => {
  return <img src={props.src} style={styles.media} />;
};

const Media = (props) => {
  const entity = props.contentState.getEntity(
    props.block.getEntityAt(0)
  );
  const {src} = entity.getData();
  const type = entity.getType();

  let media;
  if (type === 'image') {
    media = <Image src={src} />;
  }

  return media;
};

function mediaBlockRenderer(block) {
  if (block.getType() === 'atomic') {
    return {
      component: Media,
      editable: false,
    };
  }

  return null;
}

// . . . . .
<Editor
   blockRendererFn={mediaBlockRenderer}

截至2021 年

Draftjs v 0.11.2react-draft- wysiwyg 1.14.7集成。

我能夠添加執行以下操作的圖像。

const addImage = () => {

    // CREATE <img /> block
    const entityKey = editorState // from STATE
      .getCurrentContent()
      .createEntity('IMAGE', 'MUTABLE', {
        src:'some_img_url',
        height: '100px',
        width: '100px',
    }).getLastCreatedEntityKey();
     
    // NEW EDITOR STATE
    const newEditorState = AtomicBlockUtils.insertAtomicBlock(
      editorState,
      entityKey,
      ' '
    );

    // SETSTATE
    setEditorState(newEditorState);
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM