js DOM 元素ID就是全局变量


Posted in Javascript onSeptember 20, 2012

标准规范

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试验时,的确有警告.

js DOM 元素ID就是全局变量

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

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

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

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

Javascript 相关文章推荐
让textarea控件的滚动条怎是位与最下方
Apr 20 Javascript
js location.replace与location.reload的区别
Sep 08 Javascript
关于ExtJS4.1:快捷键支持的问题
Apr 24 Javascript
jqGrid增加时--判断开始日期与结束日期(实例解析)
Nov 08 Javascript
给应用部分的js代码设定一个统一的入口
Jun 15 Javascript
Bootstrap开发实战之第一次接触Bootstrap
Jun 02 Javascript
微信小程序 摇一摇抽奖简单实例实现代码
Jan 09 Javascript
angularjs 缓存的使用详解
Mar 19 Javascript
vue+axios+promise实际开发用法详解
Oct 15 Javascript
解决Angularjs异步操作后台请求用$q.all排列先后顺序问题
Nov 29 Javascript
解决echarts中横坐标值显示不全(自动隐藏)问题
Jul 20 Javascript
react 路由Link配置详解
Nov 11 Javascript
JavaScript NaN和Infinity特殊值 [译]
Sep 20 #Javascript
JavaScript 更严格的相等 [译]
Sep 20 #Javascript
JavaScript 反科里化 this [译]
Sep 20 #Javascript
Array.prototype.concat不是通用方法反驳[译]
Sep 20 #Javascript
JavaScript 用Node.js写Shell脚本[译]
Sep 20 #Javascript
一个简单的网站访问JS计数器 刷新1次加1次访问
Sep 20 #Javascript
javascript分页代码(当前页码居中)
Sep 20 #Javascript
You might like
《PHP边学边教》(02.Apache+PHP环境配置――下篇)
2006/12/13 PHP
特详细的PHPMYADMIN简明安装教程
2008/08/01 PHP
PHP集成FCK的函数代码
2008/09/27 PHP
第三章 php操作符与控制结构代码
2011/12/30 PHP
php生成curl命令行的方法
2015/12/14 PHP
Zend Framework框架之Zend_Mail实现发送Email邮件验证功能及解决标题乱码的方法
2016/03/21 PHP
js 获取屏幕各种宽高的方法(浏览器兼容)
2013/05/15 Javascript
简单谈谈jQuery(function(){})与(function(){})(jQuery)
2014/12/19 Javascript
深入理解JavaScript系列(41):设计模式之模板方法详解
2015/03/04 Javascript
javascript中clipboardData对象用法详解
2015/05/13 Javascript
使用Raygun对Node.js应用进行错误处理的方法
2015/06/23 Javascript
js实现跨域的多种方法
2015/12/25 Javascript
Bootstrap学习笔记之css样式设计(2)
2016/06/07 Javascript
基于jQuery实现淡入淡出效果轮播图
2020/07/31 Javascript
Vuejs第七篇之Vuejs过渡动画案例全面解析
2016/09/05 Javascript
WEB开发之注册页面验证码倒计时代码的实现
2016/12/15 Javascript
浅谈node的事件机制
2017/10/09 Javascript
解决npm安装Electron缓慢网络超时导致失败的问题
2018/02/06 Javascript
JS合并两个数组的3种方法详解
2019/10/24 Javascript
vue随机验证码组件的封装实现
2020/02/19 Javascript
js Math数学简单使用操作示例
2020/03/13 Javascript
微信小程序实现页面监听自定义组件的触发事件
2020/11/01 Javascript
Vuex实现简单购物车
2021/01/10 Vue.js
对python中的高效迭代器函数详解
2018/10/18 Python
十行代码使用Python写一个USB病毒
2019/06/21 Python
python logging.info在终端没输出的解决
2020/05/12 Python
CSS3 中的@keyframes介绍
2014/09/02 HTML / CSS
戴尔加拿大官网:Dell加拿大
2016/09/17 全球购物
教师党性分析材料
2014/02/04 职场文书
国贸专业自荐信范文
2014/03/02 职场文书
高三霸气励志标语
2014/06/24 职场文书
2014年爱国卫生工作总结
2014/11/22 职场文书
2015年乡镇纪检工作总结
2015/04/22 职场文书
2015年圣诞节寄语
2015/08/17 职场文书
公司趣味运动会开幕词
2016/03/04 职场文书
基于Python实现nc批量转tif格式
2022/08/14 Python