js DOM 元素ID就是全局变量

 更新时间:2012年09月20日 23:36:14   作者:  
有人在twitter上提到了:在Chrome的JavaScript终端中,你只需要输入一个元素的ID,就可以访问到这个元素.@johnjbarton给了解释,这是因为所有的元素ID都是全局变量.本文再详细解释一下
标准规范

HTML5规范文档中指出:如果一个元素符合下面两条规则中的任一条,则window对象中必须要有与之对应的一个属性,属性值就是这个对象.

  • 如果一个元素拥有ID属性,那么ID属性的属性值就会成为window对象的属性名.
  • 如果一个元素拥有name属性,那么name属性的属性值就会成为window对象的属性名.但这个元素的标签名必须是: a, applet, area, embed, form, frame, frameset, iframe, img, object,其中的一个.

让我们看一个例子.假定存在一个页面,该页面包含了一个ID属性为“foo”的div元素:

复制代码 代码如下:

<div id="foo"></div>

这样一来,上面的的div元素就可以通过window.foo(和其他的window属性一样),或者全局变量foo来访问到.比如,在Chrome控制台中,你可以这样做:

复制代码 代码如下:

> "foo" in window
true
> foo
<div id="foo"></div>


Firefox

火狐(14)的工作方式略有不同.
复制代码 代码如下:

> "foo" in window
false
> typeof foo // 这个全局变量到底有木有?
object
//错误控制台输出了下面的警告.//Element referenced by ID/NAME in the global scope.
//Use W3C standard document.getElementById() instead.

> foo
[object HTMLDivElement]
//错误控制台输出了下面的警告.//Element referenced by ID/NAME in the global scope.
//Use W3C standard document.getElementById() instead.> "foo" in window true


复制代码 代码如下:

> "foo" in window
false
> typeof foo  // 这个全局变量到底有木有?
object
//错误控制台输出了下面的警告.//Element referenced by ID/NAME in the global scope.
//Use W3C standard document.getElementById() instead.

> foo
[object HTMLDivElement]
//错误控制台输出了下面的警告.//Element referenced by ID/NAME in the global scope.
//Use W3C standard document.getElementById() instead.> "foo" in window true

这到底是怎么一回事?初始化时,window并没有属性foo.但在第一次访问这个属性的时候(通过window.foo属性直接访问或者通过全局变量foo来访问都可以),它会被自动建立.

译者注:我在Firefox14,15,18中都没有发现警告,不过在Firefox12试验时,的确有警告.



[注意:例子中的代码只能在网页中通过script标签运行才能见效,不能通过终端运行.这是因为终端在处理全局对象时,使用了不同的方式.]

译者注:我在Firebug中尝试例子中的代码,并没发现有什么差别.

一旦你尝试读取foo的值,虽然会正常返回那个div元素,但同时错误控制台会有警告,告诉你不应该那么做.很显然,这样的警告是正确的:在终端调试的时候,你可以使用这个特性,但在实际的代码中,不应该使用.

Cody Lindley写了一个jsPerf测试来比较通过全局变量访问foo和通过window.foo来访问foo的性能差别.有趣的是,只有在Firefox中访问window.foo更快点.

相关文章

  • js DOM 元素ID就是全局变量

    js DOM 元素ID就是全局变量

    有人在twitter上提到了:在Chrome的JavaScript终端中,你只需要输入一个元素的ID,就可以访问到这个元素.@johnjbarton给了解释,这是因为所有的元素ID都是全局变量.本文再详细解释一下
    2012-09-09
  • DOM 高级编程

    DOM 高级编程

    这篇文章主要介绍了DOM 高级编程,需要的朋友可以参考下
    2015-05-05
  • 什么是DOM(Document Object Model)文档对象模型

    什么是DOM(Document Object Model)文档对象模型

    文档对象模型(Document Object Model,DOM)是一种用于HTML和XML文档的编程接口。它给文档提供了一种结构化的表示方法,可以改变文档的内容和呈现方式
    2012-03-03
  • javascript针对DOM的应用分析(三)

    javascript针对DOM的应用分析(三)

    前两章讲了获取DOM元素。这章就开始讲如何操作dom。1.针对页面上有的DOM元素操作,无非就是对这个dom元素的样式进行操作
    2012-04-04
  • javascript拓展DOM操作 prependChild insertAfert

    javascript拓展DOM操作 prependChild insertAfert

    Javascript dom操作中有appendChild 和insertBefore 却没有prependChild 和insertAfter
    2010-11-11
  • Dom入门教程图解 推荐

    Dom入门教程图解 推荐

    Dom并非一种编程语言,Dom只是提供了一系列的接口,利用Dom的这些接口可以很方便的读取,修改,删除Html和XML文件中的标签元素和文本内容.在这里我们侧重于讲解Dom对Html文件的操作.
    2010-08-08
  • javascript针对DOM的应用分析(四)

    javascript针对DOM的应用分析(四)

    从这张开始就和大家说一些实用的效果的写法。当然首当其冲的就是我们可爱的TAB选项卡,用JQ写选项卡当然是很方便的而且方法也很多。其实用原生的JS写选项卡方法也很多
    2012-04-04
  • HTML Dom与Css控制方法

    HTML Dom与Css控制方法

    HTML Dom与Css的关系,大家都知道Css是用来美化网页.更改网页中元素的外观.
    2010-10-10
  • javascript针对DOM的应用实例(一)

    javascript针对DOM的应用实例(一)

    所谓针对DOM的应用。也就我这里只教大家用javascript操作页面中dom元素做交互
    2012-04-04
  • Dom 是什么的详细说明

    Dom 是什么的详细说明

    Dom 英文全称-Document Object Model 译成中文即是:文档对像模型.听起来很术语,其实就是文档内容的结构关系.文档类型可以是HTML或XML。
    2010-10-10

最新评论