解决Antd中Form表单的onChange事件中执行setFieldsValue不生效
2023-03-13 07:51:12 来源:易采站长站 作者:
目录
Antd中Form表单的onChange事件中执行setFieldsValue不生效原因是因为解决方案antd Design Form setFieldsValue的使用解决结束语Antd中Form表单的onChange事件中执行setFieldsValue不生效
如果在Form表单中onChange事件中,手写了一个setFieldsValue,>
原因是因为
Form表单会在手写的onChange事件之后执行内部的setFieldsValue,所以会将我们之前手写的setFieldsValue给覆盖掉。
解决方案
1.>
2. 使用getValueFromEvent. 是当onChange的时候,更改form表单的值的情景下使用
<FormItem label="路由节点" {...nodelayout}>
{getFieldDecorator(`node`, {
rules: [
{
required: true,
message: '选择要指定的路由节点',
}],
getValueFromEvent: (val: any) => {
let nodesArr = [] as any;
for (let item of transferList) {
for (let j of val) {
if ((item as any).id === j) {
nodesArr.push(item);
}
}
}
return nodesArr;
}
})(
<Transfer
operations={['>>', '<<']}
dataSource={transferList}
filterOption={(inputValue: any, option: any) =>
option.value.indexOf(inputValue) > -1
}
showSearch
lazy={false}
targetKeys={targetKeys}
onChange={transferHandleChange}
onSearch={transferHandleSearch}
render={item => item.value}
/>,
)}
</FormItem>
3. 如果你只想简单的更改表单的值setFieldsValue,而不是在onChange的时候触发。那么可以使用normalize. 与上述的getValueFromEvent类似,都是option的一个属性。
antd>
最近项目使用的是antd Design 4.x 版本,碰到个需要加载后端数据并展示,并且用户可以进行修改的需求,前端采用的是antd的Form表单来实现
组件加载的时候向后端请求数据
componentDidMount() {
gainCountry().then(res => {
// 这里进行数据请求
......
})
}
form表单要回填数据一般会想到的是initialValues,但是这是适用于初始化值的时候,官方文档的原话:“initialValues 不能被 setState 动态更新,你需要用 setFieldsValue 来更新”。
搜索一番setFieldsValue的使用,基本上都是:this.props.form.setFieldsValue, props自带form,试用之后发现报错,this.props下没有form,这个好像只适用于antd 3.x
解决
antd4.x>
class Index extends Component{
constructor(props) {
super(props)
this.state = { }
}
// 创建一个ref
formRef = React.createRef()
render(){
return{
{/* 绑定到Form身上*/}
<Form ref={this.formRef}>
<Form.Item name="example">
<Input />
</Form.Item>
</Form>
}
}
}
export default BaseInfo
在需要的地方进行使用:
// example 为Form.Item中的name
this.formRef.current.setFieldsValue({
example: ‘从后台返回要显示的值',
})
结束语
官方文档中都是有相关说明的,setFieldsValue>
以上为个人经验,希望能给大家一个参考,也希望大家多多支持易采站长站。













闽公网安备 35020302000061号