来源:http://www.ido321.com/948.html

直接上代码把:

   1: <div id="register">
   2:     <h4>会员注冊</h4>
   3:     <div class="formdiv">
   4:         <form method="post" action="register.php?

action=register" name="register" id="registerForm">
   5:             <dl>
   6:                 <dt>请认真填写下面内容</dt>
   7:                 <dd class="hasspan">
   8:                     用户名:<input type="text" name="username">
   9:                 </dd>
  10:                 <dd class="hasspan">
  11:                     密码:<input type="password" name="pwd">
  12:                 </dd>
  13:                 <dd class="hasspan">
  14:                     确认密码:<input type="password" name="pwdagain">
  15:                 </dd>
  16:                 <dd id="tximg">
  17:                     <img src="img/face/m01.gif" alt="选择头像" id="faceimg">
  18:                     <input type="hidden" name="touxiang" value="">
  19:                     <label id="imgsrclabel">m01.gif</label>
  20:                 </dd>
  21:                 <dd style="margin-right:120px;">
  22:                     验证码:<input type="text" name="code">
  23:                     <span>
  24:                         <img src="code.php" alt="code" id="code" name="code">
  25:                         <a href="#code" id="change">换一张</a>
  26:                     </span>
  27:                 </dd>
  28:                 <dd class="btns">
  29:                     <input type="button" name="submit" id="submit" value="注冊">
  30:                     <input type="button" name="quit" id="quit" value="退出">
  31:                 </dd>
  32:             </dl>
  33:         </form>
  34:     </div>
  35: </div>

表单数据提交到本页面,以下是js处理

   1: /*注冊表单提交*/
   2: function formDeal()
   3: {
   4:     var btnSubmit = document.getElementById('submit');
   5:     var formId = document.getElementById('registerForm');
   6:     btnSubmit.onclick = function()
   7:     {
   8:         //表单的submit()方法不能提交表单
   9:         formId.submit();
  10:     }
  11:
  12: }

假设表单提交,在本页面有一段提示信息

   1: if(!empty($_GET['action']) && $_GET['action'] == 'register')
   2: {
   3:     echo '你提交了数据';
   4:     exit();
   5: }

结果是測试了许久都没有看到提示信息,以为是代码错了或者方法写错了,细致核对。在结果官方文档,确认没有出错。

formId.submit()不能提交,就临时仅仅好把btnSubmit的type改为submit

   1: this.type="submit"

在网上查了资料,原因归结为两点:

1、表单中不能有name=”submit” 的标签

2、表单中不能缺少《enctype=”multipart/form-data”》

经測试,此两点乃荒谬。并没有解决我的问题(也许是我的问题环境不一样)

后来,以为论坛的坛友建议我把注冊button的ID改个名字,不用submit。改正之后。表单正常提交,提示信息出现。

最后总结:button的id不要设置为submit,否则可能会引起混淆,导致表单的submit()方法不能提交表单。

在命名ID时,名字最好不要和现有的api在名称上反复,避免不必要的烦扰。

下一篇:深度:蓝翔为什么这么火?

关于form.submit()不能提交表单的错误原因的更多相关文章

  1. jquery 通过submit()方法 提交表单示例

    jquery 通过submit()方法 提交表单示例: 本示例:以用户注册作为例子.使用jquery中的submit()方法实现表单提交. 注:本示例仅提供了对表单的验证,本例只用选用了三个字段作为测 ...

  2. jquery submit()不能提交表单的解决方法

    <form id="form" method="get"> <input type="text" name="q ...

  3. jQuery.Form.js 异步提交表单使用总结

    jQuery.Form.js 是一个用于使用jQuery异步提交表单的插件,它使用方法简单,支持同步和异步两种方式提交. 第一步:引入jQuery与jQuery.Form.js <script ...

  4. 调用submit()方式提交表单

    今天在看高级程序设计时看到的这样一段话: 在以调用submit()方法的形式提交表单时,不会触发submit事件 写了一个小例子做了下测试,的确如此: <form id="fm&quo ...

  5. 黄聪:jquery mobile使用form进行post提交表单没有反应,显示空白页解决方案

    jquery mobile这货会自动用Ajax方式. 所以需要在表单form标签添加data-ajax="false"这个元素. <form method="pos ...

  6. Jquery Validate不是用submit按钮提交表单,使用a标签js代码都可以

    不多说,上代码. $("#form").validate(); $("#btn").click(function() { if($("#form&qu ...

  7. (转载)PHP 下 CURL 通过 POST 提交表单失败的原因之一与解决办法

    (转载)http://blog.renren.com/share/246611432/7511385884 前几天在学习使用 CURL 时遇到一个问题:在 a.php 中以 POST 方式向 b.ph ...

  8. FORM中使用onSubmit="return false"防止表单自动提交,以及submit和button提交表单的区别

    在页面中有多个input type="text"的文本输入框的情况下没有问题,但是当页面中有只有一个文本框的情况下(),就会出现此问题. 后来在form 中添加:onsubmit= ...

  9. 使用JS对form的内容验证失败后阻止提交 &&js校验表单后提交表单的三种方法总结

    1.form的两个事件 submit,提交表单,如果直接调用该函数,则直接提交表单 onSubmit,提交按钮点击时先触发,然后触发submit事件.如果不加控制的话,默认返回true,因此表单总能提 ...

随机推荐

  1. 【PHP入门到精通】:Ch05:字符串处理

    Ch05: 字符串简介 5.1 字串说明 字符串是指由>=0个字符构成的一串字符,所以叫字符串.这里所说的字符主要包括以下几种类型:数字类型:如1, 2, 3, 4等.字母类型:如果a, b, ...

  2. 简单地Android中图片的三级缓存机制

    我们不能每次加载图片的时候都让用户从网络上下载,这样不仅浪费流量又会影响用户体验,所以Android中引入了图片的缓存这一操作机制. 原理: 首先根据图片的网络地址在网络上下载图片,将图片先缓存到内存 ...

  3. SQL跨数据库复制表数据

    SQL跨数据库复制表数据   不同服务器数据库之间的数据操作 不同数据库之间复制表的数据的方法: 当表目标表存在时: insert into 目的数据库..表 select * from 源数据库.. ...

  4. eclipse quick diff功能

    Eclipse文本编辑器和Java编辑器都提供了quick diff功能.这就使得你可以快速地识别出当前所编辑文件版本和该文件的参考版本之间的不同. 如果编辑器的quick diff功能没有启用,可以 ...

  5. 任务(Tasks)

    在Eclipse中用TODO标签管理任务,利用这个功能可以方便地将项目中一些需要处理的任务记录下来.我们可以通过在java注释里添加任务标签来标记一个任务,任务可以通过Tasks(任务)视图来察看. ...

  6. java中子类与基类变量间的赋值

    Java中子类与基类变量间的赋值 子类对象可以直接赋给基类变量. 基类对象要赋给子类对象变量,必须执行类型转换, 其语法是: 子类对象变量=(子类名)基类对象名; 也不能乱转换.如果类型转换失败Jav ...

  7. 离线树状数组 hihocoder 1391 Countries

    官方题解: // 离线树状数组 hihocoder 1391 Countries #include <iostream> #include <cstdio> #include ...

  8. JavaScript操作DOM的那些坑

    js在操作DOM中存在着许多跨浏览器方面的坑,本文花了我将近一周的时间整理,我将根据实例整理那些大大小小的“坑”. DOM的工作模式是:先加载文档的静态内容.再以动态方式对它们进行刷新,动态刷新不影响 ...

  9. Who is the best at Dataset X?

    推荐一个关于分类.目标检测.姿态估计的数据集收藏的网页. Did you ever want to quickly learn?which paper provides the best result ...

  10. Vmware虚拟机的网络设置

    设置宿主机器的Vmnat8网络适配器. 设置IP地址如图所示 设置虚拟机的的网络 选择NAT方式 启动虚拟机,设置虚拟机的网络适配器