Formik表单仅在第二次单击时更新状态

时间:2020-07-24 15:19:57

标签: reactjs forms react-native formik

我正在尝试使用Formik制作结帐表格,但是,当我单击“提交”按钮并将数据记录到控制台时,直到第二次单击,我都看不到任何更改。

        onSubmit={(values) => {
          addData(values);
          console.log(data);
        }}>
  const addData = (billing) => {
    setData((currentData) => {
      const shipping = {
        first_name: billing.first_name,
        last_name: billing.last_name,
        address_1: billing.address_1,
        address_2: billing.address_2,
        city: billing.city,
        state: billing.state,
        postcode: billing.postcode,
        country: billing.country,
      };
      return {billing, shipping, ...currentData};
    });
  };
  const [data, setData] = useState({
    payment_method: 'bacs',
    payment_method_title: 'Direct Bank Transfer',
    set_paid: true,
    line_items: [
      {
        product_id: 93,
        quantity: 2,
      },
      {
        product_id: 22,
        variation_id: 23,
        quantity: 1,
      },
    ],
    shipping_lines: [
      {
        method_id: 'flat_rate',
        method_title: 'Flat Rate',
        total: '10',
      },
    ],
  });

此外,当我要更改数据(提交时不会重置我的表单)时,我仍然看到旧数据,并且不会更新。

1 个答案:

答案 0 :(得分:-1)

我刚刚通过,我可以解决它!

它似乎只在下次点击时呈现,然后更新。

为了解决这个问题,请尝试 React useEffect Hook。这是我的 React Native 示例

import React, { useState, useEffect } from 'react';
import { View, TextInput, Button } from 'react-native';

import { Formik } from 'formik';


export const FormikPub = (props) => {

  const [formikPub, setFormikPub] = useState(
    {foo: '', bar:''}
  )

  useEffect(() => {
    console.log(`After setFormikPub(): ${JSON.stringify(formikPub)}`)
  }, [formikPub]);
 
  return (
    <Formik
      initialValues={{ foo: '', bar: '' }}
      onSubmit={(values) => {
        setFormikPub(values)
      }}
      >
      {({ handleChange, handleBlur, handleSubmit, values }) => (
        <View>
          <TextInput
              name='foo'
              placeholder="Foo"
              onChangeText={handleChange('foo')}
              onBlur={handleBlur('foo')}
              value={values.foo}
          />
          <TextInput
              name='bar'
              placeholder="Bar"
              onChangeText={handleChange('bar')}
              onBlur={handleBlur('bar')}
              value={values.bar}
          />
          
          <Button color="#004686" onPress={handleSubmit} title="Publish Formik" />
        </View>
      )}
    </Formik>
  );
}

它也许可以让你按下按钮,只有当你改变文本输入时它才会运行。