但是对于document.getElementsByName 与document.getElementById 这个两个方法,IE中是并没有严格区分 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 同样可以访问到目标元素,而通过 getName 传入 Id 也可以访问到目标元素。
MSDN中对两个方法的解释:
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确实对 getElementsByName 方法做了说明:“具有指定 Name 或者 ID 属性的元素都会返回”,但是
getElementById 方法却没有说明,然而内部实现同 getElementsByName 是一样的。
而对于FF,看来更忠实W3C标准,上面的测试代码是没有办法返回目标元素的。
W3C 中的相关信息:
http://www.w3.org/TR/2000/WD-DOM-Level-1-20000929/level-one-html.html#ID-26809268
由于有这个问题,所以对ASP.NET 控件中诸如 radiobuttonlist checkboxlist,使用客户端脚本通过getElementsByName访问具有name属性的成组对象时就要注意了,因为radiobuttonlist 默认会呈现一个table来包容这些radio,而这个table id 与这些radio的name时相同的,比如:
.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’) 就是返回四个元素了,第一个元素是那个id为 RadioButtonList1 的table,
如果客户端需要有这样的script,也为代码的跨浏览器带来了的麻烦。
注:radiobuttonlist可以选择“流布局”呈现,同样会生成一个类似的外围<span/>来做为容器,也会产生这个问题。
以上就是【document.getElementsByName和document.getElementById 在IE与FF中不同实现】的全部内容了,欢迎留言评论进行交流!
© 版权声明
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!邮箱:cxysz1@tom.com
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
丞旭猿论坛
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需!
7. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
8. 精力有限,不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别
丞旭猿论坛
THE END
暂无评论内容