当前位置: 移动技术网 > IT编程>开发语言>JavaScript > js DOM 元素ID就是全局变量

js DOM 元素ID就是全局变量

2019年07月19日  | 移动技术网IT编程  | 我要评论
标准规范

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

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

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


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



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

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

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



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

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

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

cody lindley写了一个来比较通过全局变量访问foo和通过window.foo来访问foo的性能差别.有趣的是,只有在firefox中访问window.foo更快点.

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网