标准参考

无。

问题描述

各浏览器使用 document.id 和 document.name 方法获取对象引用的支持存在差异。

造成的影响

某些浏览器中通过 document.id 和 document.name 可能无法获取元素,导致脚本异常,功能不可用。

受影响的浏览器

所有浏览器  

问题分析

参考 W3C 规范中 HTML5 草案:3.1.1 Documents in the DOM

参考 W3C 规范中 HTML5 草案:3.1.4 DOM tree accessors

1. DOM 树的访问

1.1. DOM 树中的 Document 对象及 HTMLDocument 接口

浏览器中每一个 XML 和 HTML 文档都用一个 Document 对象来表示。

Document 继承了 HTMLDocument 接口。

HTMLDocument 接口定义了实现它的对象所拥有的方法和属性。其中包括资源元数据管理、DOM 树的访问、动态标记插入、用户交互和事件处理属性等。

1.2. 访问 DOM 树中节点的方法

W3C 在 HTML5 草案中规定了一系列 DOM 树节点的访问方式,并不包括 document.id 或 document.name。

访问 DOM 树中某个节点的方法,W3C 中推荐的是使用 document.getElementById(id),根据一个元素的 id 属性获取它的 DOM 节点对象。

还有很多其他的方式,也可以获取页面上的元素,但这些方式不是 W3C 标准中规定的,所以对这些方法的支持因浏览器而异。这其中,就有使用 document.id 或 document.name 获取元素的方式。

2. 使用document.id 和 document.name 访问 DOM 树中的节点

使用 document.id 和 document.name 访问 DOM 树中节点的方法,可以访问 IMG 元素、IFRAME 元素和 FORM 元素。

除了 Opera IE 同时支持用 document.id 和 document.name 访问这 3 种元素的节点对象外,而其它浏览器对用其 name 和 id 的支持有所不同。

分析以下代码:

<script>
window.onload = function(){
document.getElementById("info").innerHTML = "document.id :" + !!document.iframe_id+
"<br/>document.name : " + !!document.iframe_name;
}
</script>
<iframe id="iframe_id" name="iframe_name"></iframe>
<div id="info"></div>
  • 以上测试用例中使用 document.id 和 document.name 的方法获取 DOM 树中的 IFRAME 元素引用,如果存在则返回 true,否则返回 false 。
  • 获取元素后的返回值将输出到 info 中

上面测试用例中,IE Opera 均全返回 true,Firefox 返回 false,而 Safari Chrome 中 document.id 是 false,document.name 是 true。

用其他元素替换 IFRAME 元素,可以测试其它元素的情况。 如下表:

获取方式 IE6 IE7 IE8 Firefox Chrome Safari Opera
Q S Q S Q S Q S Q S Q S Q S
document.div_id N N N N N N N N N N N N N N
document.div_name N N N N N N N N N N N N N N
document.span_id N N N N N N N N N N N N N N
document.span_name N N N N N N N N N N N N N N
document.select_id N N N N N N N N N N N N N N
document.select_name N N N N N N N N N N N N N N
document.a_id N N N N N N N N N N N N N N
document.a_name N N N N N N N N N N N N N N
document.input_id N N N N N N N N N N N N N N
document.input_name N N N N N N N N N N N N N N
document.img_id Y Y Y Y Y Y Y Y Y Y Y Y Y Y
document.img_name Y Y Y Y Y Y Y Y Y Y Y Y Y Y
document.form_id Y Y Y Y Y Y N N N N N N Y Y
document.form_name Y Y Y Y Y Y Y Y Y Y Y Y Y Y
document.iframe_id Y Y Y Y Y Y N N N N N N Y Y
document.iframe_name Y Y Y Y Y Y N N Y Y Y Y Y Y
document.object_id Y Y Y Y Y Y Y Y Y Y Y Y Y Y
document.object_name Y Y Y Y Y Y Y Y Y Y Y Y Y Y
document.embed_id Y Y Y Y Y Y Y Y N N N N Y Y
document.embed_name Y Y Y Y Y Y Y Y Y Y Y Y Y Y

说明:

  • 此汇总表中 Q 代表 Quirks Mode,S 代表 Standards Mode;
  • 以 document.element_id、document.element_name 表示获取方式,如 document.div_id 表示利用 id 属性获取 DIV 元素对象,而 document.span_name 表示使用 SPAN 元素的 name 属性来获取它的对象。

解决方案

使用 W3C 标准中的 document.getElementById(id) 方法获取对象。

各浏览器对使用 document.id 和 document.name 获取对象的支持存在差异的更多相关文章

  1. name值与id值在Js获取元素时的区别

    1.适用范围 除base.head.html.script.meta.title标签外,id都可以用:name只适用于select.form.frame.iframe.img.a.input等中. H ...

  2. 点击图片或者鼠标放上hover .图片变大. 1)可以使用css中的transition, transform 2) 预先设置一个 弹出div. 3)弹出层 alert ; 4) 浏览器的宽度document.documentElement.clientWidth || document.body.clientWidth

    变大: 方法一: 利用css属性. 鼠标放上 hover放大几倍. .kecheng_02_cell_content img { /*width: 100px; height: 133px;*/ wi ...

  3. 用JAVA编写浏览器内核之实现javascript的document对象与内置方法

    原创文章.转载请注明. 阅读本文之前,您须要对浏览器怎样载入javascript有一定了解. 当然,对java与javascript本身也须要了解. 本文首先介绍浏览器载入并执行javascript的 ...

  4. jquery中的$("#id")与document.getElementById("id")的区别

    以前一直认为jquery中的$("#id")和document.getElementByIdx_x("id")得到的效果是一样的,今天做特效的时候才发现并不是这 ...

  5. 不同浏览器对document.documentElement和document.body的scrollheight ,scrollTop,clientHeight以及判断滚动条是否滚动到页面最底部 【转载】

    前段时间学习怎么写一个瀑布流的时候,就接触到document.documentElement和document.body的区别,然后今天查资料的时候看到这篇博客,遂转载记录在此. 两种特殊的文档属性可 ...

  6. Make the “Check out” function available in the office document opened with Document ID link

    I found a solution to make the “Check out” function available in the office document opened with Doc ...

  7. document.documentElement和document.body区别以及获取浏览器的宽高

    原文:http://www.jb51.net/article/41410.htm 1.区别: body是DOM对象里的body子节点,即 <body> 标签: documentElemen ...

  8. function $(id) { return typeof id === "string" ? document.getElementById(id) : id; }

    function $(id) {   return typeof id === "string" ? document.getElementById(id) : id; } 这句代 ...

  9. document.body、document.documentElement和window获取视窗大小的区别

    来源:http://www.ido321.com/906.html 在w3school关于window对象的介绍中,介绍了获取浏览器窗口大小的三种方法(浏览器的视口,不包括工具栏和滚动条). 对于In ...

随机推荐

  1. C语言面试题

    #include <stdio.h> int main() { ] = {, , , , }; ); // <==> (unsigned int)&a+sizeof(* ...

  2. Ubuntu16.04安装配置Eclipse 以及opencv的使用

    安装配置http://www.oracle.com下载与自己电脑系统对应的JDK.我下载的是jdk-8u101-linux64.tar.gz 解压:sudo tar -zxvf jdk-8u101-l ...

  3. 中大bbs

    发现个好像很好玩的东东, 中大bbs: luit -encoding gbk telnet bbs.sysu.edu.cn

  4. Python复习笔记-字典和文件操作

    抽时间回顾2年前自己做过的python工具,突然感觉不像自己写的,看来好久没用过python的字典和文件操作了,查询资料和网页,整理如下: 一.字典 键值对的集合(map) 字典是以大括号“{}”包围 ...

  5. JAVA 多线程和并发学习笔记(一)

    一.进程与线程 1. 进程 当一个程序进入内存运行时,即变成一个进程.进程是处于运行过程中的程序.进程是操作系统进行资源分配和调度的一个独立单位.进程的三个特征: 独立性 独立存在的实体,每个进程都有 ...

  6. js事件委托,可以使新添加的元素具有事件(event运用)

    miaov视频教程  http://study.163.com/course/courseMain.htm?courseId=231002 <!DOCTYPE html PUBLIC " ...

  7. JAVA编程规则【转自java编程思想】

    本附录包含了大量有用的建议,帮助大家进行低级程序设计,并提供了代码编写的一般性指导: (1) 类名首字母应该大写.字段.方法以及对象(句柄)的首字母应小写.对于所有标识符,其中包含的所有单词都应紧靠在 ...

  8. css设置中文字体(font-family:"黑体")后样式失效问题

    做项目时偶遇的一诡异问题,同样的代码,在ff和IE7以上页面显示正常,但IE6无论怎么改都不起作用,本来以为是IE6的某些浮动bug所致,结果弄了很长时间也不行,后来不经意间把原来设定的font-fa ...

  9. Hibernate对象的状态

    站在持久化的角度, Hibernate 把对象分为 4 种状态: 1. 持久化状态 2. 临时状态 3. 游离状态 4. 删除状态 Session 的特定方法能使对象从一个状态转换到另一个状态. 下面 ...

  10. SQL SERVER 批量插入记录

    --create function insertData(@count as int,@tsn as bigint,@id as int) --as --begin SET IDENTITY_INSE ...