如何防止Enter键触发提交 [英] How to prevent enter key triggering submit

查看:0
本文介绍了如何防止Enter键触发提交的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在使用Formik用于React应用中的一个小表单。

方法handleSubmit在用户按Enter键时触发。

有什么方法可以防止这种触发吗? 我在以前的文档中没有找到任何东西...

谢谢。

推荐答案

您可以按如下方式添加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>
  );
}

请参阅CodeSandboxexample here

这篇关于如何防止Enter键触发提交的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆