如何防止输入键触发提交

Pet*_*ier 6 reactjs formik

FormikReact应用程序中使用了一个小表单。

handleSubmit当用户按下回车键时触发该方法。

有没有办法防止这种触发?我在 formik 文档中没有找到任何内容...

谢谢。

Mad*_*one 15

您可以添加这样的onKeyDown处理程序:

/**
 * Stop enter submitting the form.
 * @param keyEvent Event triggered when the user presses a key.
 */
function onKeyDown(keyEvent) {
  if ((keyEvent.charCode || keyEvent.keyCode) === 13) {
    keyEvent.preventDefault();
  }
}

/**
 * Sample form component.
 */
function Example() {
  return (
    <Formik initialValues={{ name: "" }} onSubmit={() => console.log("Submit")}>
      <Form onKeyDown={onKeyDown}>
        <div>
          <label htmlFor="name">Name</label>
          <Field id="name" name="name" type="text" />
        </div>
        <button type="submit">Submit</button>
      </Form>
    </Formik>
  );
}
Run Code Online (Sandbox Code Playgroud)

请参阅此处的CodeSandbox示例

  • 它将阻止文本区域输入 (4认同)