vue+element Form键盘回车事件页面刷新解决

ゞ 浴缸里的玫瑰 2022-04-03 03:45 514阅读 0赞

问题描述:如下代码所示,使用element-ui 中的el-form组件对table进行条件查询,当查询条件仅有一项时,使用@keyup.enter.native事件绑定回车事件,出现点击回车后,浏览器会刷新页面的问题;

  1. <el-form :inline="true" class="demo-form-inline">
  2. <el-form-item label="基金名称:" style="margin-bottom:0">
  3. <el-input placeholder="基金名称" @keyup.enter.native="doFilter(5)" v-model="likeName"></el-input>
  4. </el-form-item>
  5. <el-form-item style="margin-bottom:0">
  6. <el-button class="btnCheck" @click="doFilter(5)" style="margin-bottom:0">查询</el-button>
  7. </el-form-item>
  8. </el-form>

搜索了问题触发原因,是由于当表单只有一个文本框时,按下回车将会触发表单的提交事件, 导致页面的刷新。

解决方案一:加一个隐藏的文本框,即表单不只有一个文本框,如下:

  1. <el-form :inline="true" class="demo-form-inline" >
  2. <el-form-item label="基金名称:" style="margin-bottom:0">
  3. <el-input placeholder="基金名称" @keyup.enter.native="doFilter(5)" v-model="likeName"></el-input>
  4. </el-form-item>
  5. <el-form-item style="margin-bottom:0;display:none;">
  6. <el-input @keyup.enter.native="doFilter(5)"></el-input>
  7. </el-form-item>
  8. <el-form-item style="margin-bottom:0">
  9. <el-button class="btnCheck" @click="doFilter(5)" style="margin-bottom:0">查询</el-button>
  10. </el-form-item>
  11. </el-form>

element官方解决方案:在el-from 加上 @submit.native.prevent

  1. <el-form :inline="true" class="demo-form-inline" @submit.native.prevent>
  2. <el-form-item label="基金名称:" style="margin-bottom:0">
  3. <el-input placeholder="基金名称" @keyup.enter.native="doFilter(5)" v-model="likeName"></el-input>
  4. </el-form-item>
  5. <el-form-item style="margin-bottom:0">
  6. <el-button class="btnCheck" @click="doFilter(5)" style="margin-bottom:0">查询</el-button>
  7. </el-form-item>
  8. </el-form>

以上两种方案均可解决。

来源:https://segmentfault.com/a/1190000016034270

发表评论

表情:
评论列表 (有 0 条评论,514人围观)

还没有评论,来说两句吧...

相关阅读