盘点JavaScript 事件和方法提交那些事儿

开发 前端
提交表单时,会触发 submit 事件,它通常用于在将表单发送到服务器之前对表单进行校验,或者中止提交,并使用 JavaScript 来处理表单。

[[415013]]

大家好,我进阶学习者。

一、前言

提交表单时,会触发 submit 事件,它通常用于在将表单发送到服务器之前对表单进行校验,或者中止提交,并使用 JavaScript 来处理表单。

form.submit() 方法允许从 JavaScript 启动表单发送。可以使用此方法动态地创建表单,并将其发送到服务器。

二、事件:submit

1. 提交表单主要有两种方式。

第一种 :

点击 <input type="submit"> 或 <input type="image">,

第二种 :在 input 字段中按下 Enter 键。

这两个行为都会触发表单的 submit 事件。

处理程序可以检查数据,如果有错误,就显示出来,并调用 event.preventDefault(),这样表单就不会被发送到服务器了。

案例:

在文本字段中按下 Enter 键。点击 <input type="submit">。

这两种行为都会显示 alert,而因为代码中的 return false,表单不会被发送到别处。

  1. <form onsubmit="alert('submit!');return false"
  2.             First: Enter in the input field  
  3.         <input type="text" value="text"><br> 
  4.             Second: Click "submit": <input type="submit" value="Submit"
  5.         </form> 

2. submit 和 click 的关系

在输入框中使用 Enter 发送表单时,会在 <input type="submit"> 上触发一次 click 事件。

这很有趣,因为实际上根本没有点击。

例 :

  1. <form onsubmit="return false"
  2.  <input type="text" size="30" value="Focus here and press enter"
  3.  <input type="submit" value="Submit" onclick="alert('click')"
  4. </form> 

三、方法:submit

如果要手动将表单提交到服务器,可以调用 form.submit()。

这样就不会产生 submit 事件。这里假设如果开发人员调用 form.submit(),就意味着此脚本已经进行了所有相关处理。

有时该方法被用来手动创建和发送表单,如下所示:

  1. <script> 
  2.             let form = document.createElement('form'); 
  3.             form.action = 'https://google.com/search'
  4.             form.method = 'GET'
  5.             form.innerHTML = '<input name="q" value="test">'
  6.             // 该表单必须在文档中才能提交 
  7.             document.body.append(form); 
  8.             form.submit(); 
  9. </script> 

 

运行结果:

重置表单

为< input >或< button >标签设置type=“reset"属性可以定义重置按钮。

  1. <inpu type="reset" value="重置"
  2. <button type="reset">重置</button> 

当单击重置按钮时,表单将被重置,所有表单字段恢复为初始值。这是会触发reset事件。1

例:单击【重置】按钮,弹出提示,恢复文本框默认值。

  1. <!DOCTYPE html> 
  2. <html> 
  3.     <head> 
  4.         <meta charset="UTF-8"
  5.         <title></title> 
  6.     </head> 
  7.     <body> 
  8.         <form id="form1" name="form1" method="post" action=""
  9.             <input type="text" name="t" id="t" /> 
  10.             <input type="reset"  name="重置"/> 
  11.         </form> 
  12.         <script> 
  13.             var t = document.getElementsByTagName("input")[0]; 
  14.             var f = document.getElementById("form1"); 
  15.             f.onreset = function(e){ 
  16.                 alert(t.value); 
  17.             } 
  18. </script> 
  19.     </body> 
  20. </html> 

 

 

 

 

 

运行结果:

注:

在提交表单禁用提交按钮的时候,应该在“submit”事件添加事件处理函数。不要用click。

因为不同的浏览器存在时差,有的浏览器会在触发表单的submit事件之前触发click事件,有的在这之后。

四、总结

本文基于JavaScript基础,介绍了 事件和方法提交, submit 和 click 的关系对比。通过案例的分析,在实际应用需要注意的点,遇到的问题,提供有效的解决方案。

欢迎大家积极尝试,有时候看到别人实现起来很简单,但是到自己动手实现的时候,总会有各种各样的问题,切勿眼高手低,勤动手,才可以理解的更加深刻。

代码很简单,希望对你学习有帮助。

本文转载自微信公众号「前端进阶学习交流」,可以通过以下二维码关注。转载本文请联系前端进阶学习交流公众号。

 

责任编辑:武晓燕 来源: 前端进阶学习交流
相关推荐

2013-08-28 10:18:48

2021-04-07 10:02:51

Python字典Python基础

2021-04-28 10:01:06

Python基础项目

2012-12-28 10:26:08

山寨App抄袭

2022-11-04 07:57:59

编程编码编译器

2021-04-17 10:05:57

Python字符串Python基础

2012-07-31 09:14:20

苹果三星

2018-08-17 10:30:52

JavaDocker限制

2012-12-19 09:14:31

Linux

2011-02-25 14:35:00

2022-02-08 17:39:04

MySQL服务器存储

2018-09-26 06:50:19

2021-06-02 08:33:31

TPCTPC-H系统

2021-08-30 10:25:48

JavaScript进阶操作前端

2023-01-31 16:35:34

JavaScript测试框架

2021-08-26 10:25:04

JavaScript进阶操作 前端

2021-06-09 13:28:40

密码安全身份认证数据安全

2013-12-26 14:23:03

定位系统GPS监测

2013-01-18 09:26:58

2021-05-22 09:44:21

PythonNumpy数组Python矩阵
点赞
收藏

51CTO技术栈公众号