これは、draft.jsエディターに画像を挿入しようとしている私のコードです。しかし、私は失敗しました。ボタンをクリックすると、空の行が数行しか挿入されませんでしたが、何が問題なのですか?
MyEditor.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, ' ');
};
}
App.js
class App extends Component {
render() {
return (
<MyEditor/>
);
}
}
export default App;
結果
画像のサポートには、draft-js-image-pluginなどのdraft-js画像プラグインを使用する必要があります: https://www.draft-js-plugins.com/plugin/image
デフォルトでは、draft-jsはプラグインをサポートしていないため、draft-js機能を拡張するdraft-js-plugins-editorを使用することをお勧めします。
したがって、コードは次のようになります。
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, " ");
};
}
ドラフト-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",