zoukankan      html  css  js  c++  java
  • antd使用中遇到的问题

    基于antd 3.26.16版本中,使用hook,新增弹窗使用form表单遇到的问题

    1.首先导出时候需要加上Form.create

      正确:export default Form.create({name: 'sourceDialog'})(SourceDialog);

      错误:export default SourceDialog;

    2.在编写表单时,Radio组件设置defaultValue报错

    报错:Warning: `defaultValue` is invalid for `getFieldDecorator` will set `value`, please use `option.initialValue` instead.

      错误代码:

    <Form.Item label='模式'>
                            {getFieldDecorator('method', {
                                initialValue: sourceForm.method,
                                rules: [{required: true, message: '请选择模式'}],
                            })(
                                <Radio.Group defaultValue={sourceForm.method} onChange={(val) => {
                                    setSourceForm({
                                        ...setSourceForm,
                                        method: val,
                                    })
                                }}>
                                    {tableKeys.map((item) =>
                                        <Radio.Button value={item.name} key={item.key}>{item.name}</Radio.Button>
                                    )}
                                </Radio.Group>
                            )}
    </Form.Item>
    

      正确代码:

    <Form.Item label='模式'>
                            {getFieldDecorator('method', {
                                initialValue: sourceForm.method,
                                rules: [{required: true, message: '请选择模式'}],
                            })(
                                <Radio.Group onChange={(val) => {
                                    setSourceForm({
                                        ...setSourceForm,
                                        method: val,
                                    })
                                }}>
                                    {tableKeys.map((item) =>
                                        <Radio.Button value={item.name} key={item.key}>{item.name}</Radio.Button>
                                    )}
                                </Radio.Group>
                            )}
    </Form.Item>
    

     总结:Form.Item 子组件的 defaultValue 参数都要被 getFieldDecorator 中的 initialValue 替换。

     3.在组件Switch中设置报错

    报错:[antd: Switch] `value` is not validate prop, do you mean `checked`?

    错误代码:

    <Form.Item label='kerberos认证'>
                            {getFieldDecorator('kerberos', {
                                initialValue: sourceForm.kerberos,
    
                            })(
                                <Switch checkedChildren="是" unCheckedChildren="否" disabled={disabled} />
                            )}
    </Form.Item>

    正确代码:

    <Form.Item label='kerberos认证'>
                            {getFieldDecorator('kerberos', {
                                initialValue: sourceForm.kerberos,
                                valuePropName: 'checked'
                            })(
                                <Switch checkedChildren="是" unCheckedChildren="否" disabled={disabled} />
                            )}
    </Form.Item>
    

     总结:发现在getFieldDecorator包裹下的Switch组件无法显示为true的状态,Switch组件是通过checked的属性来显示状态的,所以需要一个额外的属性valuePropName

  • 相关阅读:
    EF数据库初始化策略及种子数据的添加
    Win10 FaceAPI小demo开发问题汇总
    本地Git服务器的搭建及使用
    JSP利用freemarker生成基于word模板的word文档
    Mvc项目架构分享之项目扩展
    mvc项目架构搭建之UI层的搭建
    mvc项目架构分享系列之架构搭建之Repository和Service
    mvc项目架构分享系列之架构搭建之Infrastructure
    mvc项目架构分享系列之架构搭建初步
    [svc]HTTPS证书生成原理和部署细节
  • 原文地址:https://www.cnblogs.com/jiazhi88/p/12802953.html
Copyright © 2011-2022 走看看