HTML元素的ID和Name屬性的區(qū)別_Div+CSS教程
第一種解釋:
HTML元素的ID和Name屬性的區(qū)別
一直認(rèn)為ID和NAME是一樣的,兩個(gè)又可以一起出現(xiàn),甚是疑惑。
今天BAIDU了一下,才發(fā)現(xiàn)里面大有文章。發(fā)出來研究研究:
最classical的答案:ID就像是一個(gè)人的身份證號(hào)碼,而Name就像是他的名字,ID顯然是唯一的,而Name是可以重復(fù)的。
顯然這個(gè)ID和Name的解答說的太籠統(tǒng)了,當(dāng)然那個(gè)解釋對(duì)于ID來說是完全對(duì)的,它就是Client端HTML元素的Identity。而Name其實(shí)要復(fù)雜的多,因?yàn)镹ame有很多種的用途,所以它并不能完全由ID來代替,從而將其取消掉。具體用途有:
用途1: 作為可與服務(wù)器交互數(shù)據(jù)的HTML元素的服務(wù)器端的標(biāo)示,比如input、select、textarea、和button等。我們可以在服務(wù)器端根據(jù)其Name通過Request.Params取得元素提交的值。
用途2: HTML元素Input type='radio'分組,我們知道radio button控件在同一個(gè)分組類,check操作是mutex的,同一時(shí)間只能選中一個(gè)radio,這個(gè)分組就是根據(jù)相同的Name屬性來實(shí)現(xiàn)的。
用途3: 建立頁(yè)面中的錨點(diǎn),我們知道<a href="URL">link</a>是獲得一個(gè)頁(yè)面超級(jí)鏈接,如果不用href屬性,而改用Name,如:<a name="PageBottom"></a>,我們就獲得了一個(gè)頁(yè)面錨點(diǎn)。
用途4: 作為對(duì)象的Identity,如Applet、Object、Embed等元素。比如在Applet對(duì)象實(shí)例中,我們將使用其Name來引用該對(duì)象。
用途5: 在IMG元素和MAP元素之間關(guān)聯(lián)的時(shí)候,如果要定義IMG的熱點(diǎn)區(qū)域,需要使用其屬性u(píng)semap,使usemap="#name"(被關(guān)聯(lián)的MAP元素的Name)。
用途6: 某些特定元素的屬性,如attribute,meta和param。例如為Object定義參數(shù)<PARAM NAME = "appletParameter" VALUE = "value">或Meta中<META NAME = "Author" CONTENT = "Dave Raggett">。
顯然這些用途都不是能簡(jiǎn)單的使用ID來代替掉的,所以HTML元素的ID和Name的卻別并不是身份證號(hào)碼和姓名這樣的區(qū)別,它們更本就是不同作用的東西。
轉(zhuǎn)帖:http://tieba.baidu.com/f?kz=194837029
第二種解釋:
可以說幾乎每個(gè)做過Web開發(fā)的人都問過,到底元素的ID和Name有什么區(qū)別阿?為什么有了ID還要有Name呢?! 而同樣我們也可以得到最classical的答案:ID就像是一個(gè)人的身份證號(hào)碼,而Name就像是他的名字,ID顯然是唯一的,而Name是可以重復(fù)的。
上周我也遇到了ID和Name的問題,在頁(yè)面里輸入了一個(gè)input type="hidden",只寫了一個(gè)ID='SliceInfo',賦值后submit,在后臺(tái)用Request.Params["SliceInfo"]卻怎么也去不到值。后來恍然大悟因該用Name來標(biāo)示,于是在input里加了個(gè)Name='SliceInfo',就一切ok了。
第一段里對(duì)于ID和Name的解答說的太籠統(tǒng)了,當(dāng)然那個(gè)解釋對(duì)于ID來說是完全對(duì)的,它就是Client端HTML元素的Identity。而Name其實(shí)要復(fù)雜的多,因?yàn)镹ame有很多種的用途,所以它并不能完全由ID來代替,從而將其取消掉。具體用途有:
用途1: 作為可與服務(wù)器交互數(shù)據(jù)的HTML元素的服務(wù)器端的標(biāo)示,比如input、select、textarea、和button等。我們可以在服務(wù)器端根據(jù)其Name通過Request.Params取得元素提交的值。
用途2: HTML元素Input type='radio'分組,我們知道radio button控件在同一個(gè)分組類,check操作是mutex的,同一時(shí)間只能選中一個(gè)radio,這個(gè)分組就是根據(jù)相同的Name屬性來實(shí)現(xiàn)的。
用途3: 建立頁(yè)面中的錨點(diǎn),我們知道<a href="URL">link</a>是獲得一個(gè)頁(yè)面超級(jí)鏈接,如果不用href屬性,而改用Name,如:<a name="PageBottom"></a>,我們就獲得了一個(gè)頁(yè)面錨點(diǎn)。
用途4: 作為對(duì)象的Identity,如Applet、Object、Embed等元素。比如在Applet對(duì)象實(shí)例中,我們將使用其Name來引用該對(duì)象。
用途5: 在IMG元素和MAP元素之間關(guān)聯(lián)的時(shí)候,如果要定義IMG的熱點(diǎn)區(qū)域,需要使用其屬性u(píng)semap,使usemap="#name"(被關(guān)聯(lián)的MAP元素的Name)。
用途6: 某些特定元素的屬性,如attribute,meta和param。例如為Object定義參數(shù)<PARAM NAME = "appletParameter" VALUE = "value">或Meta中<META NAME = "Author" CONTENT = "Dave Raggett">。
顯然這些用途都不是能簡(jiǎn)單的使用ID來代替掉的,所以HTML元素的ID和Name的卻別并不是身份證號(hào)碼和姓名這樣的區(qū)別,它們更本就是不同作用的東西。
當(dāng)然HTML元素的Name屬性在頁(yè)面中也可以起那么一點(diǎn)ID的作用,因?yàn)樵贒HTML對(duì)象樹中,我們可以使用document.getElementsByName來獲取一個(gè)包含頁(yè)面中所有指定Name元素的對(duì)象數(shù)組。Name屬性還有一個(gè)問題,當(dāng)我們動(dòng)態(tài)創(chuàng)建可包含Name屬性的元素時(shí),不能簡(jiǎn)單的使用賦值element.name = "..."來添加其Name,而必須在創(chuàng)建Element時(shí),使用document.createElement('<element name = "myName"></element>')為元素添加Name屬性。這是什么意思啊?看下面的例子就明白了。
<script language="JavaScript">
var input = document.createElement('INPUT');
input.id = 'myId';
input.name = 'myName';
alert(input.outerHTML);
</script>
消息框里顯示的結(jié)果是:<INPUT id=myId>。
<script language="JavaScript">
var input = document.createElement('<INPUT name="myName">');
input.id = 'myId';
alert(input.outerHTML);
</script>
消息框里顯示的結(jié)果是:<INPUT id=myId name=myName>。
初始化Name屬性的這個(gè)設(shè)計(jì)不是IE的缺陷,因?yàn)镸SDN里說了要這么做的,可是這樣設(shè)計(jì)的原理什么呢?我暫時(shí)沒有想太明白。
這里再順便說一下,要是頁(yè)面中有n(n>1)個(gè)HTML元素的ID都相同了怎么辦?在DHTML對(duì)象中怎么引用他們呢?如果我們使用ASPX頁(yè)面,這樣的情況是不容易發(fā)生的,因?yàn)閍spnet進(jìn)程在處理aspx頁(yè)面時(shí)根本就不允許有ID非唯一,這是頁(yè)面會(huì)被拋出異常而不能被正常的render。要是不是動(dòng)態(tài)頁(yè)面,我們硬要讓ID重復(fù)那IE怎么搞呢?這個(gè)時(shí)候我們還是可以繼續(xù)使用document.getElementById獲取對(duì)象,只不過我們只能獲取ID重復(fù)的那些對(duì)象中在HTML Render時(shí)第一個(gè)出現(xiàn)的對(duì)象。而這時(shí)重復(fù)的ID會(huì)在引用時(shí)自動(dòng)變成一個(gè)數(shù)組,ID重復(fù)的元素按Render的順序依次存在于數(shù)組中。
轉(zhuǎn)帖:http://www.cnblogs.com/birdshome/archive/2005/01/31/99562.html
- DIV+CSS設(shè)計(jì)的誤區(qū)
- CSS基礎(chǔ):常用CSS英文字體介紹
- IE6和IE7中border邊框斷線現(xiàn)象
- border:none;與border:0;的有什么不同?
- div+css下js對(duì)聯(lián)廣告不隨屏幕滾動(dòng)的解決方法
- divcss教程:深入了解css的行高Line Height屬性
- CSS文檔流,塊級(jí)元素和內(nèi)聯(lián)元素
- 5個(gè)你該知道的CSS3新技術(shù)
- 用正則表達(dá)式替換a標(biāo)記href值
- 30個(gè)優(yōu)秀的CSS導(dǎo)航和按鈕設(shè)計(jì)教程
- css中px和em有什么區(qū)別
- img圖片元素下多余空白解決方案
Div+CSS教程Rss訂閱Div+Css教程搜索
Div+CSS教程推薦
- CSS對(duì)文字溢出時(shí)的自動(dòng)隱藏處理
- IE6的雙倍邊距BUG
- 學(xué)習(xí)Web標(biāo)準(zhǔn)不要對(duì)IE抱有偏見
- CSS入門教程:縱向下拉及多級(jí)彈出式菜單
- DIVCSS中id于class的區(qū)別詳解
- web標(biāo)準(zhǔn)中IE無法設(shè)置滾動(dòng)條顏色解決方法
- 如何實(shí)現(xiàn)多風(fēng)格選擇樣式實(shí)時(shí)切換?
- 不規(guī)則文字排版的CSS樣式如何定義?
- 網(wǎng)頁(yè)制作中如何精確還原設(shè)計(jì)稿的幾個(gè)步驟
- DivCSS布局?jǐn)U展技巧和用法
猜你也喜歡看這些
- CSS菜單:基本橫向菜單效果超炫
- DIV CSS JS仿kijiji導(dǎo)航條
- DIVCSS圖形菜單之仿DreamWeaver
- CSS布局實(shí)例:隱藏input文字
- CSS布局教程:DIV CSS三列式布局的實(shí)現(xiàn)方法
- DIV CSS布局入門示例(二)寫入整體層結(jié)構(gòu)與CSS
- DivCSS布局實(shí)例:很實(shí)用的圖文混排CSS列表-富有語(yǔ)義
- CSS導(dǎo)航菜單:仿淘寶首頁(yè)導(dǎo)航條布局效果
- CSS菜單:一個(gè)圖片構(gòu)建菜單的三種狀態(tài)一例!
- DivCSS實(shí)例:符合web標(biāo)準(zhǔn)的嵌入Flash的方法-JS調(diào)用
- 相關(guān)鏈接:
- 教程說明:
Div+CSS教程-HTML元素的ID和Name屬性的區(qū)別。