亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

淺談html中id和name的區別實例代碼

2020-10-23 18:33:33
字體:
來源:轉載
供稿:網友
我們可以通過一段代碼來分析一下其中的微妙差別:

<form method="post" action="" name="demoform">
<input type="text" name="oDemo" id=”oDemo2” value="DEMO" />
</form>



在IE瀏覽器里,我們可以通過多少方法來索引到這個文本框對象?(為區別起見,我們把NAME和ID設成了不同的值)
1. oDemo
2. demoform.oDemo
3. document.all.oDemo
4. document.all.demoform.oDemo
5. document.forms[0].oDemo
6. document.forms['demoform'].oDemo
7. document.forms['demoform'].childNodes[0]
8. document.forms['demoform'].elements[0]
9. document.getElementById('oDemo2')

以上9種索引方法在IE6里面全部通過返回值測試,不過值得注意的是最后一種:在IE6里,我把索引對象寫成

document.getElementById('oDemo'),瀏覽器也能正確索引到對象,真是可怕的容錯性?。?!

接著問題來了,我們把這段代碼放在Mozilla Firefox 1.0里再執行一次,只有第7種方法返回“undefined”,其他的方法可以正確

索引到對象,不過由于第3、4種方法用到了document.all這個IE專有對象,FF1.0雖然返回了正確的值,不過卻在控制臺里發出了警

告:警告:非標準的屬性 document.all。請使用 W3C 的標準形式 document.getElementById() 。

接下來我們把HTML文本類型定義得嚴格一點,在源代碼開頭加上:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

使HTML文本按照HTML4.01標準去解析,在IE6里照樣全部通過返回值測試,不過在Mozilla Firefox 1.0里麻煩就大了,第3、4種方法

沒有任何的返回值,而在控制臺里發出了報錯信息:錯誤: document.all has no properties ,而第7種方法依舊返回“undefined

”。

小 結

name原來是為了標識之用,但是現在根據規范,都建議用id來標識元素。

以下只能用name:  
   1.    表單(form)的控件名,提交的數據都用控件的name而不是id來控制。因為有許多name會同時對應多個控件,比如

checkbox和radio,而id必須是全文檔中唯一的。此外瀏覽器會根據name來設定發送到服務器的request。因此如果用id,服務器是無

法得到數據的。  
   2.    frame和window的名字,用于在其他frame或window指定target。  

以下只能用id:  
   1.    label與form控件的關聯,  
   <label for="MyInput">My    Input</label>  
   <input id="MyInput"    type="text">  
   for屬性指定與label關聯的元素的id,不可用name替代。  
   2.    CSS的元素選擇機制,以#MyId的方式指定應用樣式的元素,不能用name替代。  
   3.    腳本中獲得對象:  
   IE支持在腳本中直接以id(而不是name)引用該id標識的對象。例如上面的input,要在腳本中獲得輸入的內容,可以直接以

MyInput.value來獲得。  
   如果用DOM的話,則用document.getElementById("MyInput").value,如果要用name的話,通常先得到包含控件的form,例如

document.forms[0],然后從form再引用name,注意這樣得到的是經過計算后將發送給服務器的值。  

name與id的其他區別是:
   id要符合標識的要求,比如大小寫敏感,最好不要包含下劃線(因為不兼容CSS)。而name基本上沒有什么要求,甚至可以用數字

。

用CSS控制這個鏈接的停留樣式,
可以這樣寫 #m_blog div.opt a:hover{color:#D57813} 或 #myLink:hover{color:#D57813}

NAME主要應用在交互式網頁,表單提交給某個服務器端腳本后接收變處理量使用。從源代碼的規范性和兼容性角度出發,如在客戶端

腳本里要索引某個對象,建議用document.getElementById()方法,盡量不要直接使用NAME的值,當然如果不考慮兼容性,以上9種方

法都可以在IE里運行通過(IE5.0沒測試過)。

附:測試源代碼

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>     <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
    <title></title>
</head>
<body>
<form method="post" action="" name="demoform">
    <input type="text" name="oDemo" value="DEMO" id="oDemo2" /><br />
    <input type="button" value="oDemo" onclick="alert(oDemo.value)" /><br />
    <input type="button" value="demoform.oDemo" onclick="alert(demoform.oDemo.value)" /><br />
    <input type="button" value="document.all.oDemo" onclick="alert(document.all.oDemo.value)" /><br />
    <input type="button" value="document.all.demoform.oDemo" onclick="alert(document.all.demoform.oDemo.value)" /><br />
    <input type="button" value="document.forms[0].oDemo" onclick="alert(document.forms[0].oDemo.value)" /><br />
    <input type="button" value="document.forms['demoform'].oDemo" onclick="alert(document.forms['demoform'].oDemo.value)" /><br />
    <input type="button" value="document.forms['demoform'].childNodes[0]" onclick="alert(document.forms
['demoform'].childNodes[0].value)" /><br />
    <input type="button" value="document.forms['demoform'].elements[0]" onclick="alert(document.forms
['demoform'].elements[0].value)" /><br />
    <input type="button" value="document.getElementById('oDemo2')" onclick="alert(document.getElementById('oDemo2').value)" /><br />
</form>
</body>
</html>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧日韩不卡在线视频| 精品国产网站地址| 成人在线精品视频| 国产拍精品一二三| 精品久久久久国产| 亚洲人成电影网站色www| 欧美激情一区二区三区高清视频| 自拍亚洲一区欧美另类| 国产精品一区二区在线| 狠狠躁夜夜躁人人躁婷婷91| 欧美精品生活片| 日本a级片电影一区二区| 亚洲精品美女久久久久| 久久精品91久久香蕉加勒比| 一区二区日韩精品| 欧美精品在线看| 欧美日韩一区二区精品| 久久久久久国产精品| 亚洲欧美国产精品专区久久| 91精品久久久久久久久青青| 亚洲精品美女免费| 亚洲精品中文字幕有码专区| 久久最新资源网| 欧美有码在线视频| 久久国产精品久久久久| 国产精品男人爽免费视频1| 2019av中文字幕| 国产欧亚日韩视频| 欧美丰满少妇xxxxx| 一级做a爰片久久毛片美女图片| www.日韩.com| 欧美老女人性生活| 最新日韩中文字幕| 国产欧美一区二区三区视频| 国产精品黄色影片导航在线观看| 久久九九亚洲综合| 中文字幕成人在线| 国内精品久久久久久影视8| 亚洲第一av网站| 欧美三级免费观看| 久久久久久高潮国产精品视| 亚洲v日韩v综合v精品v| 色综合天天综合网国产成人网| 精品一区二区亚洲| 亚洲a级在线播放观看| 欧美—级a级欧美特级ar全黄| 亚洲另类欧美自拍| 91精品国产色综合| 国模极品一区二区三区| 午夜美女久久久久爽久久| 久久影视电视剧免费网站清宫辞电视| 欧洲精品毛片网站| 日韩经典中文字幕在线观看| 欧美日韩国产激情| 1769国产精品| 国产综合在线视频| 91色中文字幕| 国产婷婷色综合av蜜臀av| 日韩欧美国产网站| 中文字幕精品一区二区精品| 日韩毛片在线观看| 777777777亚洲妇女| 97在线免费观看| 亚洲跨种族黑人xxx| 日韩精品欧美激情| 亚洲欧美成人精品| 国产又爽又黄的激情精品视频| 欧美最猛性xxxxx亚洲精品| 亚洲精品电影在线| 午夜精品久久久久久久久久久久| 欧美激情视频网址| 亚洲精品xxxx| 国产一区二区色| 国产精品高潮呻吟久久av野狼| 国产在线98福利播放视频| 欧美国产亚洲视频| 91牛牛免费视频| 国产精品午夜视频| 欧美性猛交xxxx免费看| 亚洲成人精品av| 欧美亚洲在线观看| 亚洲第一二三四五区| 中文字幕综合在线| 亚洲第一中文字幕在线观看| 欧美精品aaa| 韩国日本不卡在线| 欧美日韩国产成人在线观看| 国产一区私人高清影院| 久久99青青精品免费观看| 中文字幕亚洲欧美日韩2019| 欧洲一区二区视频| 欧美久久精品午夜青青大伊人| 国产日韩欧美中文| 久久躁狠狠躁夜夜爽| 久99久在线视频| 久久精品成人欧美大片古装| 亚洲网址你懂得| 成人欧美一区二区三区在线| 久久国产加勒比精品无码| 精品国产一区二区三区四区在线观看| 国产精品免费小视频| 日韩中文字幕国产精品| 亚洲女同性videos| 1769国内精品视频在线播放| 国产精品免费一区豆花| 国产自摸综合网| 亚洲视频精品在线| 日韩av大片免费看| 欧美日韩福利在线观看| 国产精品99久久久久久人| 久久久999国产精品| 亚洲国产精品久久久久秋霞不卡| 国产激情久久久| 亚洲在线观看视频| 精品国产一区二区三区久久狼5月| 日本高清不卡的在线| 高清视频欧美一级| 成人黄色短视频在线观看| 欧美国产日韩二区| 国产精品久久久久久久美男| 日韩av影片在线观看| 精品福利樱桃av导航| 国产精品99久久久久久www| 91中文字幕一区| 国产精国产精品| 成人h猎奇视频网站| 亚洲色图在线观看| 日韩精品中文字| 欧美资源在线观看| 国产精品视频久久| 韩国三级日本三级少妇99| 韩国日本不卡在线| 91国产精品视频在线| 久久精品视频在线| 96pao国产成视频永久免费| 九九热最新视频//这里只有精品| 在线视频中文亚洲| 久久777国产线看观看精品| 亚洲欧美日韩一区二区在线| 欧美一级免费看| 国产精品美女久久| 国产午夜精品视频免费不卡69堂| 在线观看欧美日韩国产| 亚洲国产精品久久久久久| 成人免费观看a| 亚洲欧美日韩直播| 久久久久久久激情视频| 精品在线小视频| 国产日韩欧美在线看| 亚洲美女www午夜| 日韩亚洲在线观看| 欧美日韩国产激情| 久久这里有精品视频| 日韩高清不卡av| 欧美裸体男粗大视频在线观看| 久久视频在线观看免费| 国产精品高清免费在线观看| 亚洲在线免费看| 国产日韩欧美夫妻视频在线观看| 亚洲欧洲在线播放| 91精品久久久久久久久久久久久久| 激情亚洲一区二区三区四区| 日韩精品免费综合视频在线播放| 孩xxxx性bbbb欧美|