form表单那些事

结论:
1 建议使用button[type=submit]来提交表单,而不是input;
2 只有单行文本控件时,回车会引发表单提交;
3 通过onsubmit事件可阻止表单提交

表单提交方式

input[type=submit] 或input[type=image]

<form method="get" action="./menut.html" id="form">
  <input name='key'>
  </input value='ok' type='submit'>
</form>

点击提交按钮可以提交
但是有个问题,如果给<input type="submit" name="btn"/>,提交后的结果为:


Paste_Image.png

注意其中form的URL为./menut.html?key=123&btn=ok. 作为按钮的input控件同时被当做一个表单输入提交给了服务器。那么这个提交按钮到手是交互控件还是数据控件呢?定位是有些不清晰。再加上它的样式难以定制,不可作为其他标签的容器,所以建议不要用input作为表单提交按钮。

button[type=submit]
button的语义很明确,就是一个按钮,不包含数据,作用就是用户交互。但它也有type和value属性。type的默认值是submit(IE下是button),所以点击一个button会提交表单

<form method="get" action="">
  <input name='key'>
  <button type="submit">确定</button> 
  //最好还是加上type="submit",因为在IE浏览器中button的type默认是button,这意味着它只是一个按钮而不会提交表单
</form>

不幸的是,button居然和input[type=submit]一样,可以设置name和value.提交表单时,value也会被作为表单数据提交给服务器。相比较而言,还是建议用button作为交互用的按钮,来提交表单。同时请注意设置type=submit来兼容IE

Enter键提交表单
Enter键是可以提交表单的!分为两种情况:
1 单行文本控件(指的是type为text 而非textarea)回车可以提交表单。
2 只要表单中存在以下列出的任何一种按钮,那么在相应表单控件拥有焦点的情况下,按回车键就可以提交表单(textarea 是个例外)。如果表单中没有提交按钮,按回车键就不会提交表单。

<input type="submit" value="ok">

<button type="submit"></button>

<input type="image" src="1.png">

通过form.submit()提交表单

<form method="get" action="">
  <input name="name" type="text" >
  <button type="button" value="ok" onclick="A()">
</form>

function A () {
  if(){
    return false;
  }else {
    document.forms[0].submit();
  }
}

阻止表单提交

1 在表单中加上onsubmit = "return false;" 可以阻止表单提交。

<script>  
function submitFun(){  
    //逻辑判断  
    return true; //允许表单提交  
    //逻辑判断  
    return false;//不允许表单提交  
}  
</script>  
<form onsubmit="return submitFun();"> //注意此处不能写成 onsubmit="submitFun();"否则将表单总是提交  
</form>  

form表单中陷阱

描述:最近遇到一次处理form数据的过滤,采用了button的onclick事件来检查,发现return false后表单仍然提交了
仔细研究了下onclick, onsubmit, submit集合函数之间的关系和区别

<form action="#" method="POST" name="A" onsubmit="return X();">
  <input type="text" value="" />
  <input onclick="Y()" type="submit" value="提交"/>
</form>

自己写了X(),Y()函数,我们会发现,这几个函数的执行顺序

1) onclick: Y();  
2) onsubmit: X();
3) submit();

也就是说:
只要onclick 未return false 那么就继续执行onsubmit
只要onsubmit未return false那么表单就被提交出去了
正确写法

<input type="submit" onclick="return X()">
//X()返回false后,form的submit会被终止

错误写法

<input type="submit" onclick="X()">
//X()返回false后,form的submit会继续
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 201,468评论 5 473
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 84,620评论 2 377
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 148,427评论 0 334
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,160评论 1 272
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,197评论 5 363
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,334评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,775评论 3 393
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,444评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,628评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,459评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,508评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,210评论 3 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,767评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,850评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,076评论 1 258
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,627评论 2 348
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,196评论 2 341

推荐阅读更多精彩内容