猿问

无法更新反应状态

我试图将新对象推入反应状态,但数组状态始终返回空。


这是我的反应状态:


this.state = {


          formname: '',

          newform : [],

          formField: {},

          formsCollection: []

        };

来自状态的对象结果formField:


{0: {…}, 1: {…}, formname: "form 1"}

  0: {type: "text", label: "First Name", title: "", name: "", uniquekey: "", …}

  1: {type: "", label: "Last Name", title: "", name: "", uniquekey: "", …}

  formname: "form 1"

  __proto__: Object

}

更新状态的表单 onSubmit() 处理函数:


onSubmit= (e) => 

    {   

      e.preventDefault();


      const finalData = {formname: this.state.formname, ...this.state.newform};


      let formField = Object.assign(this.state.formField, finalData);


      this.setState({

        formField

      });


      console.log(this.state.formField, 'single form field');


      // const formsCollection = this.state.formsCollection.slice();




      // if(formsCollection.length){

      //   this.setState({ formsCollection: formsCollection });

      // }

      // else{

      //   formsCollection.push(formField);

      //   this.setState({ formsCollection : formsCollection });

      // }



      this.setState((prevState) => ({

        formsCollection: [...prevState.formsCollection, formField]

      }));


      console.log(this.state.formsCollection, 'forms collection are: ')


    };

每次单击 onSubmit() 时,它都会将单个formField对象打印到控制台,但不会将新对象添加到formsCollection数组中。此外,我同时使用了 prevState 和 spread 运算符方法,但在这两种情况下,console.log(this.state.formsCollection, 'forms collection are: ')每次都向我打印一个空数组。


请帮助解决这个问题。


HUX布斯
浏览 107回答 3
3回答

慕少森

setState是异步的,因此您不会立即看到状态值的更改。您可以向它传递一个回调函数,其中更新的状态值可用:this.setState({  formField}, () => console.log(this.state.formField, 'single form field')); 另一个问题是您直接使用 修改您的状态Object.assign,setState而是使用功能形式: this.setState(state => ({   ...state,   formField: {     formname: state.formname,     ...state.newform   } }));

青春有我

setState 异步工作,这就是为什么您看不到更新的状态,您可以使用回调作为this.setState((prevState) => ({    formsCollection: [...prevState.formsCollection, formField]  }), () => {     console.log(this.state.formsCollection, 'forms collection are: ')});希望能帮助到你

慕森王

试试这个   this.setState(prevState => {        prevState.formsCollection = [...prevState.formsCollection, formField];        return prevState;      });
随时随地看视频慕课网APP

相关分类

JavaScript
我要回答