zoukankan      html  css  js  c++  java
  • 表单自动提交问题整理

    表单自动提交问题

    问题描述

    二是利用了浏览器的默认行为(至少发现ie是这样的)。浏览器在解析网页的时候,有许多默认的行为,例如: * 如果一个页面上有表单和一个提交按钮,那么打开页面时,焦点会自动落在这个提交按钮上面。 * 同样如果一个表单中只有一个单行文本输入域(text),那么在这个输入域中按Enter键时,浏览器会自动提交该表单。 我们对于第一种情况一般都知道而且很容易理解,但是对于第二种浏览器的默认行为,可能知道这一点的人就比较少了,下面我具体看一下浏览器(至少ie如此)在表单提交上的默认行为。 如果表单中含有一个单行文本输入域,那么无论含有多少其他类型的表单组件,那么在该输入域中点击Enter时,表单会自动提交。例如下面的代码: <form action="" method="post"> <input type="text" name="sdfsdf"/> <textarea</textarea> <input type="checkbox"sdfsdf> <input type="hidden"name="aa"/> </form>如果表单中含有两个或多个单行文本输入域,那么无论是否含有其他类型的表单组件,按Enter键时不会自动提交,例如: <form action="" method="post"> <input type="text" name="sdfsdf"/> <input type="text" name="sddf"/> </form>

    解决方法

    办法很简单,我们上面举的例子中已经有了,只要再添加一个文本输入框就可以了,可能你会说,为了不自动提交就要增加一个没有用的输入框,而且中含有两个输入框最终用户会接受吗?其实可以解决,你可以将那个新添加的输入框通过style隐藏即可,例如: <form action="" method="post"> <input type="text" name="notautosubmit" style="display:none"/> <input type="text" name="username"/> </form>还有一个方法可以绑定button按钮 enter触发事件:document.onkeypress = function(){ if(event.keyCode == 13) { search(); returnfalse; } } 其中search方法是onclick事件:

    注意:1、form自动提交,input最好不要有value=""配置(有次设置时焦点在input上时点击enter表单会自动提交)。

  • 相关阅读:
    算法导论(第三版)Exercises2.1(插入排序、线性查找、N位大数相加)
    含铝馒头可能损伤儿童的智力
    每秒3600乘以100等于36万次售票解决方案
    namespace Measure
    public interface ICloneable
    VB.net 与线程
    C#调用VP 包含素材
    C# 定时器 一个简单 并且可以直接运行的Demo
    松下 激光位移传感器 API
    在Win7系统下, 使用VS2015 打开带有日文注释程序出现乱码的解决方案
  • 原文地址:https://www.cnblogs.com/weilantiankong/p/5142879.html
Copyright © 2011-2022 走看看