gpt4 book ai didi

javascript - React - 使用 draftjs 的 redux-form initialValues

转载 作者:行者123 更新时间:2023-11-29 17:49:49 26 4
gpt4 key购买 nike

我正在尝试使用 draft-js对于我的应用程序中的富文本编辑器,使用 redux-form,我面临的问题是我无法将 initialValues 从 draft-js 填充到编辑器中,我的代码看起来像这样

<form onSubmit={handleSubmit(this.onFormSubmit.bind(this))}>

<Field
name="websiteurl"
placeholder="INSERT WEBSITE URL HERE"
component={this.renderFieldText}
mandatory='true'
/>

<Field
name="htmlcontent"
placeholder="ENTER HTML CONTENT HERE"
component={this.renderRichTextEditor}
/>
<Button bsStyle="primary" type="submit" className="pull-right" loading={this.state.loading}>Save</Button>

</form>


renderRichTextEditor(field){
return (
<RichTextEditor placeholder={field.placeholder}/>
);
}

renderFieldText(field){
var divClassName=`form-group ${(field.meta.touched && field.meta.error)?'has-danger':''}`;
divClassName = `${divClassName} ${field.bsClass}`;
return(
<div className={divClassName}>
<input
className="form-control"
type={field.type}
placeholder={field.placeholder}
{...field.input}
/>
</div>
);
}

我有两个字段 websiteurlhtmlcontent,组件 websiteurl 填充了 initialValues,但我不知道如何使用在 RichTextEditor 组件中实现的 draft-js 编辑器..

如果有人取得过这样的成就,请帮忙。

谢谢。

最佳答案

我喜欢为 Rich Editor 的“字段组件”创建一个单独的组件,以免混淆表单组件。个人喜好真的。

<Field name="content" component={EditorField} />

移动到 EditorField 组件...

  constructor(props: Props) {
super(props);
// here we create the empty state
let editorState = EditorState.createEmpty();
// if the redux-form field has a value
if (props.input.value) {
// convert the editorState to whatever you'd like
editorState = EditorState.createWithContent(convertFromHTML(props.input.value));
}
// Set the editorState on the state
this.state = {
editorState,
};
}

编写onChange函数

onChange = (editorState: Object) => {
const { input } = this.props;
// converting to the raw JSON on change
input.onChange(convertToRaw(editorState.getCurrentContent()));
// Set it on the state
this.setState({ editorState });
};

现在在渲染函数中,继续放置您的编辑器组件。传递 Redux 表单输入 Prop 、您的 onChange 函数和编辑器状态。

<Editor
{...input}
onEditorStateChange={this.onChange}
editorState={editorState} />

现在您可以像通常使用没有 Draft-js 的 redux-form 一样设置 initialValues。

关于javascript - React - 使用 draftjs 的 redux-form initialValues,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45085019/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com