cla*_*rkf 7 javascript email reactjs react-hook-form
提交表单后出现错误:
TypeError: e.preventDefault is not a function。
这是我的代码:
import {React} from 'react';
import emailjs from 'emailjs-com';
import {useForm} from "react-hook-form";
const NameForm = () => {
const { register, handleSubmit, formState: { errors } } = useForm();
const sendEmail = (e) => {
e.preventDefault();
emailjs.sendForm('YOUR_SERVICE_ID', 'YOUR_TEMPLATE_ID', e.target, 'YOUR_USER_ID')
.then((result) => {
console.log(result.text);
}, (error) => {
console.log(error.text);
});
e.target.reset();
}
return (
<div>
<h1 className="text-center text-md-left mb-3">Get in Touch</h1>
<form className="contact-form" onSubmit={handleSubmit(sendEmail)}>
<div className="form-group mb-0 py-3">
<textarea className="form-control custom--fields-mod text-the-primary" id="message" rows="3" placeholder="Message *" name="message" {...register("message", { required: true })}></textarea>
{errors.message && <span className="invalid-feedback d-block">Please fill out this field.</span>}
</div>
<div className="form-group row py-2 mb-0">
<div className="col-md-6">
<div>
<div className="d-flex align-items-center">
<input className="mr-2" type="checkbox" id="yes_i_understand" name="yes_i_understand" {...register("yes_i_understand", { required: true })} />
<label className="font-size-12 mb-0" htmlFor="yes_i_understand">I understand and agree to the Privacy Policy and Terms and Conditions.</label>
</div>{errors.yes_i_understand && <span className="invalid-feedback d-block">You must agree before submitting.</span>}
</div>
</div>
<div className="col-md-6 text-center text-md-left py-2 py-md-0">
<input className="buttons-width float-md-right btn btn-dark-moderate-orange rounded-0" type="submit" value="SEND MESSAGE" />
</div>
</div>
</form>
</div>
);
}
export default NameForm;
Run Code Online (Sandbox Code Playgroud)
我看到了反应钩子表单示例,但我不确定我是否错过了将数据传递到表单的某些内容。
您可以在这里查看: https ://codesandbox.io/s/react-hook-form-using-emailjs-2k6x5
虽然纪尧姆的答案解决了问题,但以下解决方案将是仅使用react-hook-form而不使用event对象来处理它的方法。因此只需使用该emailjs.send方法并将 RHF 提供的表单值传递给该方法即可。要重置表单,您可以使用resetRHF 的方法。
const {
register,
handleSubmit,
reset,
formState: { errors }
} = useForm();
const sendEmail = (formData) => {
emailjs
.send("YOUR_SERVICE_ID", "YOUR_TEMPLATE_ID", formData, "YOUR_USER_ID")
.then(
(result) => {
console.log(result.text);
},
(error) => {
console.log(error.text);
}
);
reset();
};
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
17578 次 |
| 最近记录: |