亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

react中滿足對自己的組件使用setFieldsValue

發布時間:2023-03-11 15:40:18 來源:億速云 閱讀:100 作者:iii 欄目:開發技術

這篇文章主要介紹“react中滿足對自己的組件使用setFieldsValue”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“react中滿足對自己的組件使用setFieldsValue”文章能幫助大家解決問題。

    react對自己的組件使用setFieldsValue

    setFieldsValue的用法

    setFieldsValue是antd form的一個api,其作用是對指定的已使用from包裹的表單進行value設置。那么所以它的功能也很簡單,那就是給指定的input設置value。

    如下所示:

    import React from "react";
    import { Form, Input } from 'antd';
    
    class TestForm extends React.Component {
      componentDidMount(){
        const { setFieldsValue } = this.props.form;
        // 這里就能實現指定表單設置value
        setTimeout(()=>{
            setFieldsValue({"username": "Tom"})
        },5000)
      }
      render() {
        const { getFieldDecorator } = this.props.form;
        return (
          <Form >
            <Form.Item>
              {getFieldDecorator('username', {})(<Input />)}
            </Form.Item>
          </Form>
        );
      }
    }
    
    export default Form.create()(TestForm)

    問題

    那么假如把

    {getFieldDecorator('username', {})(<Input />)}

    換成

    {getFieldDecorator('username', {})(<TestInput />)}

    setFieldsValue 設置的value去哪了?相信聰明的你一眼就看透了,自然是在TestInput上面。假如TestInput是我們自定義的組件,那么我們則可以在props中找value這個屬性,那么假如我們的Input是自定義的input組件,我們可以這么寫

    import React from "react";
    import { Input } from 'antd';
    
    class TestInput extends React.Component {
    
        state = {
            value: ""
        }
        
        componentWillReceiveProps(nextProps){
            if(nextProps.value){
                this.setState({
                    value: nextProps.value
                })
            }
        }
        
        render() {
            return (
              <div >
                  <Input value={this.state.value}/>
              </div>
            );
          }
    }
    
    export default TestInput

    這樣,我們就能使用setFieldsValue設置自定義的組件了

    使用Hooks使用setFieldsValue設置初始值無效

    react中滿足對自己的組件使用setFieldsValue

    錯誤:

      useEffect(() => {
        if (formConfigListValues.length === 0) {
          form.resetFields();
          if (statusId) {
            form.setFieldsValue({flowStatus: 1});
          }
        }
      }, [formConfigListValues, statusId]);

    因為formConfigListValues在每次操作完表單時候要走一遍,但是導致了,審批狀態一直不會變(也就是操作審核狀態失效);

    正確:

      useEffect(() => {
        if (formConfigListValues.length === 0) {
          form.resetFields();
        }
      }, [formConfigListValues]);
      
      useEffect(() => {
          if (statusId) {
            form.setFieldsValue({flowStatus: 1});
          }
      }, [statusId]);

    在hooks中使用setFieldsValue,還要注意寫代碼的順序和層級結構(如:新加的setFieldsValue到底放在里邊還是外邊,放到外邊的話是否要注意,要放在resetFields所在useEffect的下邊)。

    關于“react中滿足對自己的組件使用setFieldsValue”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    额济纳旗| 尼勒克县| 即墨市| 泗水县| 思茅市| 周口市| 云阳县| 闽清县| 马关县| 庐江县| 日土县| 怀宁县| 阿克| 肇东市| 河源市| 故城县| 兴国县| 和静县| 昌图县| 鹰潭市| 义乌市| 四子王旗| 偃师市| 新野县| 苍梧县| 工布江达县| 乐东| 都江堰市| 泾源县| 沿河| 资阳市| 黄平县| 萍乡市| 通山县| 齐齐哈尔市| 龙南县| 宕昌县| 扶绥县| 兴海县| 阿拉善盟| 青神县|