众所周知,在表单中加上οnsubmit="return false;"可以阻止表单提交。

下面是简单的一小段代码:

java代码:

 1 <form action="index.jsp" method="post" onsubmit="submitTest();">
 2
 3   <INPUT value="www">
 4
 5   <input type="submit" value="submit">
 6
 7 </form>
 8
 9 <SCRIPT LANGUAGE="JavaScript">
10
11 <!--
12
13 function submitTest() {
14   // 一些逻辑判断
15   return false;
16 }
17
18 //-->
19
20 </SCRIPT>

大家判断像上面的写法,点击submit按钮该表单是否提交?

若答案为是,就不用往下看了。

若答案为否,错了。实际情况是表单正常提交,若想它不提交,应该将

java代码:

1 <form action="index.jsp" method="post" onsubmit="submitTest();">

改为

java代码:

1 <form action="index.jsp" method="post" onsubmit="return submitTest();">

为何?

原来onsubmit属性就像是<form>这个html对象的一个方法名,其值(一字符串)就是其方法体,默认返回true;

和Java一样,在该方法体中你可以写任意多个语句,包括内置函数和自定义函数,如

java代码:

 1 οnsubmit="
 2
 3 alert('haha'); // 内置函数
 4
 5 submitTest(); // 自定义函数
 6
 7 alert(this.tagName); // 用到了this关键词
 8
 9 ......(任意多条语句)
10
11 return false;
12
13 "

就相当于

java代码:

 1 Form.prototype.onsubmit = function() {
 2
 3   alert('haha'); // 内置函数
 4
 5   submitTest(); // 自定义函数
 6
 7   alert(this.tagName); // 用到了this关键词
 8
 9   ......(任意多条语句)
10
11   return false;
12
13 };

这样的话你就覆写了(override)其默认方法(默认返回true)

大家注意到方法体中可以用this这个关键词,这里即代表了<form>的对象实例。

经过这样的分析后,以上情况就不难理解了:

java代码:

1 <form action="index.jsp" method="post" onsubmit="submitTest();">

这样写,override方法的效果为:

java代码:

1 Form.prototype.onsubmit = function() {
2   submitTest();
3 };

在这里submitTest()虽然返回false,但我们只执行了此函数,没有对其结果进行任何处理。而

java代码:

1 <form action="index.jsp" method="post" onsubmit="return submitTest();">

override方法的效果为:

java代码:

1 Form.prototype.onsubmit = function() {
2   return submitTest();
3 };

这样,我们利用到了它的返回值,达到了预期效果。

这样理解的话我想印象会深刻得多,就不易出错了

结论:

我们可以用Java里的思维方式来思考模拟JavaScript中的类似情况(JavaScript中基于prototype的面向对象技术也确实是这样做的),但他们毕竟还是有本质上的区别,如Java是强类型的,有严格的语法限制,而JavaScript是松散型的。象上述方法:

java代码:

1 Form.prototype.onsubmit = function() {
2
3 };

既可以有返回值,又可以没有返回值,在Java里是通不过的,毕竟Java里面不能靠方法的返回值不同来重载(overload)方法,而JavaScript中的重载要松散得多。

submit()和onsubmit()的区别

最近在开发中遇到了表单提交前验证的问题,用一个普通的button按钮代替submit按钮,
在提交前触发这个button的onclick事件,在其事件中触发form的submit事件。问题出现了:
以下是出现相关代码:

 1 <form action="http://www.baidu.com/s?wd=this.form.submit%28%29%3B&cl=3" method="post" name="form1" onsubmit="return alert('已提交!'); return false;">
 2   <table align="center" width="420px" cellPadding="2" cellSpacing="1" bgcolor="#A4B6D7" style="word-wrap:Break-word;">
 3     <tr style="cursor: hand;background:#d7e3f6" >
 4       <td width="20%" align="right">条型码</td>
 5       <td><input style="width:90%" type="text" name="GOODSNUM" size="30" maxlength="8" ></td>
 6     </tr>
 7     <tr>
 8       <td align="center" colspan="2">
 9         <input type="button" name="save" value="保存" onclick="if((confirm('确定要提交吗?'))) this.form.submit();"/>
10       </td>
11       </tr>
12   </table>
13 </form>

却发现并没有触发form的onsubmit方法,而是直接提交了。奇怪了,难道没有这种方式无法结合form的onsubmit方法吗?
仔细想了想,既然this.form表示form这个对象,那么肯定能获取到form的属性和方法的
,就改成this.form.onsubmit(); 成功!
我又查了查手册,原来submit的方法是这样解释的:
The submit method does not invoke the onsubmit event handler. Call the onsubmit event handler directly. When using Microsoft® Internet Explorer 5.5 and later, you can call the fireEvent method with a value of onsubmit in the sEvent parameter.

意思是说submit这个方法是不触发onsubmit时间的,如果想要触发它,需要调用
fireEvent方法。尝试一下:this.form.fireEvent('onsubmit');哈哈,果然也成功!不过这样不是多此一举吗?呵呵!

就这个小问题也搞了我将近一个小时,不过为了以后不为这个问题烦恼,这也是值得的。

1 this.form.submit(); //直接提交表单
2 this.form.onsubmit(); //调用form 的 onsubmit方法
3 this.form.fireEvent('onsubmit'); //同上,

PS:又学到了fireEvent这个方法,

2.onsubmit()与submit() :

 1 <sCript>
 2 function fun()
 3 {
 4   alert("form_submit");
 5 }
 6 </script>
 7
 8 <form onsubmit="fun()">
 9   <input type="submit" id="aaa" value="submit"> <!--能弹出form_submit-->
10   <input type="button" id="bbb" value="onCliCk_submit" onCliCk="document.forms[0].submit()">
11 <!--
12 表单会提交,但是不会运行fun() 原因是 onsubmit事件不能通过此种方式触发(在IE环境)
13 直接用脚本doCumetn.formName.submit()提交表单是不会触发表单的onsubmit()事件的
14 -->
15   <input type="button" id="bb1" value="onCliCk_onsubmit" onCliCk="document.forms[0].onsubmit()">
16
17 <!--会触发fun()参数-->
18 </form>

转载于:https://www.cnblogs.com/dandeliongogo/p/6612080.html

form表单的onsubmit()问题 集合相关推荐

  1. form表单的onsubmit() return问题

    以前在项目中为一个表单(from)编写onsubmit()脚本的时候,经常需要验证表单中数据的合法性,所以常会写道:<form action="/admin/addUser.do&qu ...

  2. form表单的onsubmit事件中调用方法时为什么前面加return

    表单(from)编写onsubmit()脚本的时候,经常需要验证表单中数据的合法性,所以常会写道:<form action="/admin/addUser.do" metho ...

  3. Form表单提交前进行JS验证的3种方式

    1. 提交按钮的onclick事件中验证 <script type="text/javascript">          function check(form) { ...

  4. form表单提交不刷新页面的方法

    方法1:给form表单加onsubmit事件,值为return false; <form action="" method="post"  οnsubmi ...

  5. html form表单提交前验证

    可以使用form表单的onsubmit方法,在提交表单之前,对表单或者网页中的数据进行检验. onsubmit指定的方法返回true,则提交数据:返回false不提交数据. <HTML>& ...

  6. form表单的submit()和onsubmit()的区别

    submit()和onsubmit()的区别 表单元素拥有submit方法,同时也具有onsubmit事件句柄,用于监听表单提交.可以使用elemForm.submit();方法触发表单提交. 1). ...

  7. form 表单 onsubmit 属性

    Html中form表单有一个onsubmit属性: 当onsubmit的值为return true时,单击提交按钮,会直接打开action指定的连接 当onsubmit的值为return false时 ...

  8. 【onsubmit】Form表单onsubmit事件用法详解

    表单提交数据时,我们有时会用到onsubmit事件,那么onsubmit事件到底是干什么用的,在什么时候触发onsubmit事件以及如何使用onsubmit.本文章将向大家详细讲解onsubmit事件 ...

  9. js form表单onsubmit事件用法详解

    onsubmit事件是当表单提交时进行相关js操作的一个事件.(但是有疑问) onsubmit 事件会在表单中的确认按钮被点击时发生.当该事件触发的函数中返回false时,表单就不会被提交. 请看下面 ...

最新文章

  1. 模拟电路技术之基础知识(一)
  2. java异常在哪一层捕获_当在一个方法的代码中抛出一个检测异常时,该异常或被方法中的 ( )结构 捕获,或者在方法的 ( ) 中声明_学小易找答案...
  3. java异步处理同步化_java 异步查询转同步多种实现方式:循环等待,CountDownLatch,Spring Even...
  4. HDU - 2296 Ring(AC自动机+dp)
  5. IIS 7.0 安装SSL证书过程
  6. Backbone.js入门学习资源
  7. .netframework游戏编程入门——模拟魔兽学院永远的羁绊
  8. 【转】精华!图解局域网共享设置步骤 - 李小虎
  9. AsyncTask更新UI线程的基本原理
  10. VMware 11 安装 OS X 10.10 虚拟机
  11. 初学Linux的简单命令(一)
  12. 加权随机采样 (Weighted Random Sampling)
  13. Emacs 显示左侧行号
  14. 中年转行,拥抱互联网(上)
  15. Android事件分发原理
  16. 【听书笔记-0515】-《清单革命》
  17. android 2.3.6Gallary源码导入到Eclipse中编译
  18. nginx常用的优化配置
  19. dialog出现Uncaught RangeError: Maximum call stack size exceeded错误
  20. IB36分斩获藤校?看艺术设计类专业

热门文章

  1. 二叉树的中序遍历—leetcode94
  2. 如何利用循环代替递归以防止栈溢出(译)
  3. kali 安装搜狗输入法
  4. 两个字符串的删除操作
  5. pygame用精灵编组的问题的猜想和验证(未完待续)
  6. [BUUCTF-pwn]——[HarekazeCTF2019]baby_rop
  7. android 强制全屏,[Android]设置Activity为全屏显示的两种方法
  8. Struts2拦截器实现异常处理机制
  9. 忘记Windows XP登录密码的9种解决办法
  10. oracle 五种索引创建