av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

input submit、button和回車(chē)鍵提交數(shù)據(jù)詳解

瀏覽:235日期:2022-06-02 18:52:26
<form>
  <input name="name">
  <input type="submit" value="提交">
</form>

以這種方式提交,input 值為22222222時(shí),后面遞交的url 就會(huì)變?yōu)閘ocalhost:3980/input.html?name=222222
其中有些值得注意的細(xì)節(jié):

    設(shè)置type=submit后,輸入控件會(huì)變成一個(gè)按鈕,顯示的文字為其value值,默認(rèn)值是Submit。
    form[method]默認(rèn)值為GET,所以提交后會(huì)使用GET方式進(jìn)行頁(yè)面跳轉(zhuǎn)。
    input[type]默認(rèn)值為text,所以第一個(gè)input顯示為文本框。

input其實(shí)是一個(gè)由輸入控件改裝過(guò)來(lái)的按鈕,這源于Web早期的簡(jiǎn)陋設(shè)計(jì)。我們給它設(shè)置name便可以驗(yàn)證這一點(diǎn):

<input name="btn" value="提交" type="submit">

提交后的Url就會(huì)變?yōu)閘ocalhost:3980/input.html?name=222222&btn=提交

注意其中的URL為/?key=foo&btn=ok。作為按鈕的input控件同時(shí)被當(dāng)做一個(gè)表單輸入提交給了服務(wù)器。 它到底是交互控件還是數(shù)據(jù)控件呢?定位是有些不清晰。再加上它的樣式難以定制、不可作為其他標(biāo)簽的容器, 所以建議不要用input作為表單提交按鈕。

注意:input的type屬性還可以是button,這時(shí)它只是一個(gè)按鈕,不會(huì)引發(fā)表單提交。

2、button[tpe=submit]button的語(yǔ)義很明確,就是一個(gè)按鈕不含數(shù)據(jù),作用就是用戶交互。但它也有type和value屬性。 type的默認(rèn)值是submit,所以點(diǎn)擊一個(gè)button會(huì)引起表單提交:

<form>
 <input name="key">
 <button>確定</button>
</form>

如果你在做IE瀏覽器的兼容,請(qǐng)記住button[type]在IE中的默認(rèn)值是button,這意味著它只是一個(gè)按鈕而不會(huì)引發(fā)表單提交。

  另外,我們通過(guò)設(shè)置元素內(nèi)容的方式來(lái)指定button的文字。這意味著button是一個(gè)容器控件, 其中可以包含任意的HTML標(biāo)簽,同時(shí)樣式更容易定制。這也是為什么Bootstrap 文檔中大量使用button作為示例的原因之一。

  但是,button會(huì)很亂。button可以設(shè)置name和value。提交表單時(shí),value會(huì)被作為表單數(shù)據(jù)提交給服務(wù)器。 在IE中,甚至?xí)裝utton開(kāi)始與結(jié)束標(biāo)簽之間的內(nèi)容作為name對(duì)應(yīng)的值提交給服務(wù)器。button和input的相似還不止于此,button也可以設(shè)置type=reset,此時(shí)點(diǎn)擊按鈕會(huì)導(dǎo)致表單被重置(這還挺有用的)。 w3school給出了如下的示例:

<form action="form_action.asp" method="get">
 First name: <input type="text" name="fname" />
 Last name: <input type="text" name="lname" />
 <button type="submit" value="Submit">Submit</button>
 <button type="reset" value="Reset">Reset</button>
</form>

對(duì)于button就不多說(shuō)了,建議用button作為交互用的按鈕,來(lái)提交表單。同時(shí)請(qǐng)注意設(shè)置type=submit來(lái)兼容IE。

回車(chē)鍵提交表單

Enter鍵是可以提交表單的!但是你可能已經(jīng)注意到了,并非所有的表單都可以用Enter鍵來(lái)提交。來(lái)看HTML2.0 標(biāo)準(zhǔn):

    When there is only one single-line text input field in a form, the user agent should accept Enter in that field as a request to submit the form.

    當(dāng)表單中只有一個(gè)單行的文本輸入控件時(shí),用戶代理應(yīng)當(dāng)接受回車(chē)鍵來(lái)提交表單。

“單行”指的是type為text而非textarea,顯然在textarea中回車(chē)提交表單是怎樣的難以接受。 其實(shí)在實(shí)踐中,有多個(gè)單行的input也可以用Enter提交,比如登錄頁(yè)面。

4.阻止表單提交

阻止表單提交也是一個(gè)常見(jiàn)的話題,通常用于客戶端的表單驗(yàn)證。通用的辦法是設(shè)置onsubmit:

<form onsubmit="return false;">
 <input name="key">
 <input value="ok" type="submit">
</form>

只需要在onsubmit的一系列語(yǔ)句最后返回false,便可以阻止它提交。 如果你希望調(diào)用一個(gè)方法來(lái)決定是否阻止提交,記得在此處返回方法的返回值:

<form onsubmit="return false;">
 <input name="key">
 <input value="ok" type="submit">
</form>
標(biāo)簽: CSS HTML
相關(guān)文章:
主站蜘蛛池模板: 国产精品免费一区二区三区 | 精品国产一区二区三区久久 | 激情 亚洲 | 成年人精品视频 | 国产91在线精品 | 国产农村一级国产农村 | 国产精品五月天 | 中文字幕一区在线 | 中文字幕精品一区二区三区精品 | 九九在线视频 | 欧美久久一级 | 久久久久电影 | 久久精品久久久久久 | 成人h视频在线观看 | 久久久精品网站 | 欧美一级艳情片免费观看 | 欧美综合一区 | 久久精品亚洲成在人线av网址 | 欧美在线成人影院 | 国产精品久久久久久 | 天堂一区二区三区 | av影音 | 亚洲第1页| 亚洲国产精品99久久久久久久久 | 日韩欧美精品 | 毛片一区二区三区 | 久久99国产精一区二区三区 | 国产高清一区二区三区 | 在线观看av网站永久 | 国产一区二区三区四区区 | 99久久免费精品国产免费高清 | 久久欧美高清二区三区 | 蜜桃免费一区二区三区 | 亚洲国产精品久久 | 最近日韩中文字幕 | 久久免费视频在线 | h片在线观看网站 | 人人澡视频 | 亚洲精品456| 青青久在线视频 | 国产在线拍偷自揄拍视频 |