input里按回车键会刷新页面 怎么办

表象:input里回车键会刷新页面
本质:触发了form表单的submit事件

两种情况:input输入框里按回车键触发submit

  1. form表单里,button,input输入框,框内按回车会触发submit
  2. form表单里,button,但是只有一个input输入框,框内按回车会触发submit,(其他非input的表单元素可有可无)。
<!-- 情况1: -->
  <form action="">
    <!-- 有输入框就行,几个无所谓 -->
    <input type="text">
    <input type="text">
    <!-- 有没有其他非input输入框的元素都无所谓 -->
    <textarea name="" id="" cols="30" rows="10"></textarea>
    <button>sss</button>
  </form>

<!-- 情况2: -->
  <form action="">
    <!-- 只有一个输入框 -->
    <input type="text">
    <!-- 有没有其他非input输入框的元素都无所谓 -->
    <textarea name="" id="" cols="30" rows="10"></textarea>
  </form>
复制代码

解决方案1:去掉form标签

毕竟本质是触发了form的submit事件,那去掉肯定解决问题,但不一定适合去掉。

解决方案2:监听submit,阻止默认行为

监听submit,阻止默认行为

<form onsubmit="event.preventDefault()">
<!-- js也行 -->
<script>
  document.querySelector('form').addEventListener('submit',function(e){
    e.preventDefault()
  })
</script>
复制代码

解决方案3:input上监测回车事件

每个input里监听回车事件:

<input type="text" name="aa" onkeypress="if(event.keyCode == 13){event.preventDefault()}">

<!-- return false也行 -->
<!-- <input type="text" name="aa" onkeypress="if(event.keyCode == 13){return false}"> -->


<!-- js也行 -->
<script>
  document.querySelector('form input').addEventListener('keypress',function(e){
    if(event.keyCode == 13) {e.preventDefault()}
  })
</script>
复制代码

解决方案4:添加一个隐藏的input(无button的情况下)

无button的情况下,增加一个隐藏的input

  <form action="">
    <!-- 只有一个输入框 -->
    <input type="text">
    <!-- 加个隐藏的 -->
    <input type="text" hidden>
    <!-- 有没有其他非input输入框的元素都无所谓 -->
    <textarea name="" id="" cols="30" rows="10"></textarea>
  </form>
复制代码

element-ui会遇到同样的问题

el-form/el-input/el-button背后是原生的form/input/button,所以会同样遇到上述问题。

解决方法也类似:

  • 去掉el-form表单
  • <el-form @submit.native.prevent>
  • 无button的情况下,增加 hidden类型的input
  • 监听input的keypress,不过稍微复杂了点,不写了

引用

© 版权声明
THE END
喜欢就支持一下吧
点赞0 分享