开发者问题收集

Formik 错误:TypeError:无法读取未定义的属性“值”

2020-10-13
6502

我是 React 和 Formik 的新手,请帮我解决这个问题,我想使用 .onSave{product 将输入的值传递给另一个组件:

import { Formik } from 'formik';
import * as Yup from 'yup';
export default class ProductForm extends React.Component {
    
    constructor(props) {
      super(props);
      this.onSubmit = this.onSubmit.bind(this);
    }
    
    onSubmit(event){
        event.preventDefault();
        var product = {};
        product.productName = this.refs.productName.value;
        product.quantity = this.refs.quantity.value;
        product.price = this.refs.price.value;
        this.props.onSave(product);
      }

    render() {
        return (
          <Formik initialValues={{productName:"",quantity:"",price:""}} validation`enter code here`Schema={Yup.object().shape({productName:Yup.string().required("Product Name is required"),quantity:Yup.number().required("Quantity is required").positive().integer(),price:Yup.number().required("Quantity is required").positive().integer()}>
    {props=>{
            const{
            values,
            touched,
            errors,
            handleChange,
            handleBlur
        }=props;
        return(<div>
            <h1>Add Product</h1>
            <form autoComplete='off' onSubmit={this.onSubmit}>
                <input type="text"   onChange={handleChange} onBlur={handleBlur}  name="productName" value={values.productName} placeholder="Enter Product Name"/>
                {
                    errors.productName && touched.productName &&(
                    <div className="errorName" >{errors.productName}</div>
                    )
                }<br></br><br></br>
                
                <input type="text"   onChange={handleChange} onBlur={handleBlur} name="quantity" value={values.quantity} placeholder="Enter Quantity"/>
                {
                    errors.quantity && touched.quantity &&(
                    <div className="errorName">{errors.quantity}</div>
                    )
                }<br></br><br></br>
                <input type="text"  onChange={handleChange} onBlur={handleBlur} name="price" value={values.price} placeholder="Enter Price"/>
                {
                    errors.price&&touched.price&&(
                    <div className="errorName">{errors.price}</div>
                    )
                }<br></br><br></br>
                
                <button type="submit" >Submit</button>
            </form>   </div>
        )
    }
    }

</Formik>
      );
    }
}
2个回答

像这样尝试

this.inputRef = React.createRef(); // 初始化

this.myInput.current // 保存对 DOM 节点的引用

class App extends React.Component {
    constructor(props) {
      super(props) 
      this.inputRef = React.createRef();
    }
  
  handleSubmit = e => {
    e.preventDefault();  
    console.log(this.inputRef.current.value);
  };

  render() {
    return (
      <div>
        <form onSubmit={this.handleSubmit}>
          <input type="text" ref={this.inputRef} />
          <button>Submit</button>
        </form>
      </div>
    );
  }
}
upog
2020-10-13

您需要考虑以下几点:

您必须将提交处理程序绑定到 formik,然后在 form 上使用它

<Formik
        initialValues={{ productName: "", quantity: "", price: "" }}
        validationSchema={Yup.object().shape({
          productName: Yup.string().required("Product Name is required"),
          quantity: Yup.number()
            .required("Quantity is required")
            .positive()
            .integer(),
          price: Yup.number()
            .required("Quantity is required")
            .positive()
            .integer()
        })}
        onSubmit={this.onSubmit}
      >
        {({
          values,
          touched,
          errors,
          handleSubmit,
          handleChange,
          handleBlur
        }) => {
          return (
            <div>
               <h1>Add Product</h1>
              <form autoComplete="off" onSubmit={handleSubmit}>
                 ....
              </form>
            </div>
          )
         );
        }}
      </Formik>

此外,提交的事件处理程序也有一些变化:

onSubmit(formData) {
    var product = {};

    product.productName = formData.productName;
    product.quantity = formData.quantity;
    product.price = formData.price;

    console.log(product);

    this.props.onSave(product);
  }

请检查 代码

Rohitha
2020-10-13