作家
登录

js DOM 元素ID就是全局变量

作者: 来源:www.28hudong.com 2013-03-30 00:23:18 阅读 我要评论

标准规范 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 windowfalse> 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更快点.

  推荐阅读

  实现网页内容水平或垂直滚动的Javascript代码

主要两个部分,一、是滚动内容部分;二、JS的滚动代码部分,也只有两句话。 一、传统的滚动代码 用Javascript实现新闻内容的水平滚动! [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行] 传统的滚动代码应用效>>>详细阅读


本文标题:js DOM 元素ID就是全局变量

地址:http://www.17bianji.com/kaifa2/JS/23097.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)