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