天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

document.getElementsByName和document.getElementById 在IE與FF中不同實(shí)現(xiàn)

對(duì)于ID & Name 按最經(jīng)典的解釋的:“ID 就如同我們的身份證,Name就如同我們的名字”,也就是說,在一個(gè)html文檔中ID是唯一的,但是Name是可以重復(fù)的,就象我們的人名可以重復(fù)但是身份證確實(shí)全中國(guó)唯一的(PS:據(jù)說有重復(fù)的^_^)
但是對(duì)于document.getElementsByName 與document.getElementById 這個(gè)兩個(gè)方法,IE中是并沒有嚴(yán)格區(qū)分 ID 與 Name 的,比如:
<script type="text/Javascript">
function useGetElementsByNameWithId(id) {
var eles = document.getElementsByName('ID_A');
var msg = '使用 getElementsByName 傳入 ID:得到:'
if(eles.length > 0) {
msg += " Name " + eles[0].id;
}
alert(msg);
}
function usegetElementByIdWithName(name) {
var ele = document.getElementById(name);
var msg = '使用 getElementById 傳入 Name 得到:';
if(ele) {
msg += " ID " + ele.id;
}
alert(msg);
}
</script><input id="ID_A" name="Name_A" type="button" value="使用 getElementsByName 傳入 ID" onclick="useGetElementsByNameWithId(this.id)" />
<input id="ID_B" name="Name_B" type="button" value="使用 getElementsByName 傳入 Name" onclick="usegetElementByIdWithName(this.name)" />IE中通過 getId 傳入 name 同樣可以訪問到目標(biāo)元素,而通過 getName 傳入 Id 也可以訪問到目標(biāo)元素。
MSDN中對(duì)兩個(gè)方法的解釋:
getElementById Method
--------------------------------------------------------------------------------
Returns a reference to the first object with the specified value of the ID attribute.
Remarks
When you use the getElementsByName method, all elements in the document that have the specified NAME or ID attribute value are returned.
Elements that support both the NAME and the ID attribute are included in the collection returned by the getElementsByName method, but not elements with a NAME expando.
MSDN確實(shí)對(duì) getElementsByName 方法做了說明:“具有指定 Name 或者 ID 屬性的元素都會(huì)返回”,但是
getElementById 方法卻沒有說明,然而內(nèi)部實(shí)現(xiàn)同 getElementsByName 是一樣的。
而對(duì)于FF,看來更忠實(shí)W3C標(biāo)準(zhǔn),上面的測(cè)試代碼是沒有辦法返回目標(biāo)元素的。
W3C 中的相關(guān)信息:
http://www.w3.org/TR/2000/WD-DOM-Level-1-20000929/level-one-html.html#ID-26809268
由于有這個(gè)問題,所以對(duì)ASP.NET 控件中諸如 radiobuttonlist checkboxlist,使用客戶端腳本通過getElementsByName訪問具有name屬性的成組對(duì)象時(shí)就要注意了,因?yàn)閞adiobuttonlist 默認(rèn)會(huì)呈現(xiàn)一個(gè)table來包容這些radio,而這個(gè)table id 與這些radio的name時(shí)相同的,比如:
.ASPx
<ASP:radiobuttonlist id="RadioButtonList1" runat="server">
<ASP:listitem>opt1</ASP:listitem>
<ASP:listitem>opt2</ASP:listitem>
<ASP:listitem>opt3</ASP:listitem>
</ASP:radiobuttonlist>HTML:
<table id="RadioButtonList1" border="0">
<tr>
<td><input id="RadioButtonList1_0" type="radio" name="RadioButtonList1" value="opt1" /><label for="RadioButtonList1_0">opt1</label></td>
</tr><tr>
<td><input id="RadioButtonList1_1" type="radio" name="RadioButtonList1" value="opt2" /><label for="RadioButtonList1_1">opt2</label></td>
</tr><tr>
<td><input id="RadioButtonList1_2" type="radio" name="RadioButtonList1" value="opt3" /><label for="RadioButtonList1_2">opt3</label></td>
</tr>
</table>
在IE中使用 document.getElementsByName('RadioButtonList1') 就是返回四個(gè)元素了,第一個(gè)元素是那個(gè)id為 RadioButtonList1 的table,
如果客戶端需要有這樣的script,也為代碼的跨瀏覽器帶來了的麻煩。
注:radiobuttonlist可以選擇“流布局”呈現(xiàn),同樣會(huì)生成一個(gè)類似的外圍<span/>來做為容器,也會(huì)產(chǎn)生這個(gè)問題。

AspNet技術(shù)document.getElementsByName和document.getElementById 在IE與FF中不同實(shí)現(xiàn),轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 妻子的秘密HD观看 | 2019精品国产品在线不卡 | 做暧暧免费30秒体验 | 国产精品高清视亚洲一区二区 | 寻找最美乡村教师颁奖晚会 | 男同志china免费视频 | 精品人妻伦一二三区久久AAA片 | 亚洲 在线 日韩 欧美 | 欧美激情视频在线观看一区二区三区 | 国产精品高清免费网站 | 四房播播开心五月 | 日本色女孩影院 | 狠狠色狠狠色狠狠五月ady | 色悠久久久久综合网小说 | 精品无码日本蜜桃麻豆 | 免费看黄色一级 | 男女全黄h全肉细节文 | 成人在免费视频手机观看网站 | 乌克兰14一18处交见血 | 校园刺激全黄H全肉细节文 校园纯肉H教室第一次 | 老师洗澡让我吃她胸的视频 | 国产一级做a爰片久久毛片男 | 99久久蜜臀亚洲AV无码精品 | 高清不卡伦理电影在线观看 | 国产国产乱老熟女视频网站97 | 中文国产乱码在线人妻一区二区 | 久久久精品国产免费A片胖妇女 | 色综合久久网女同蕾丝边 | 国偷自产视频一区二区久 | 国产成人精品综合久久久 | 日本xxx片免费高清在线 | 啊…嗯啊好深男男高h文总受 | proburn中文破解版下载 | 日韩高清一区二区三区不卡 | 黑人强伦姧人妻日韩那庞大的 | 国产成人精品久久久久婷婷 | 擦擦擦在线视频观看 | 亚洲AV精品一区二区三区不卡 | 毛片手机在线看 | 中文国产成人精品久久免费 | 女性露出奶头流出精子 |