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 相关文章推荐
JavaScript Array扩展实现代码
Oct 14 Javascript
使用jquery获取网页中图片高度的两种方法
Sep 26 Javascript
使用JavaScript修改浏览器URL地址栏的实现代码
Oct 21 Javascript
javascript和jquery修改a标签的href属性
Dec 16 Javascript
简单谈谈jQuery(function(){})与(function(){})(jQuery)
Dec 19 Javascript
分享10个原生JavaScript技巧
Apr 20 Javascript
Node.js连接mongodb实例代码
Jun 06 Javascript
详解Node项目部署到云服务器上
Jul 12 Javascript
利用vscode调试编译后的js代码详解
May 14 Javascript
Vue组件全局注册实现警告框的实例详解
Jun 11 Javascript
微信小程序ibeacon三点定位详解
Oct 31 Javascript
基于elementUI使用v-model实现经纬度输入的vue组件
May 12 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
一个域名查询的程序
2006/10/09 PHP
PHP初学入门
2006/11/19 PHP
php生成年月日下载列表的方法
2015/04/24 PHP
详解PHP的Yii框架中自带的前端资源包的使用
2016/03/31 PHP
PHP 计算两个时间段之间交集的天数示例
2019/10/24 PHP
jQuery 可以拖动的div实现代码 脚本之家修正版
2009/06/26 Javascript
jquery.pagination.js 无刷新分页实现步骤分享
2012/05/23 Javascript
JavaScript动态插入script的基本思路及实现函数
2013/11/11 Javascript
Angular中的Promise对象($q介绍)
2015/03/03 Javascript
js简单实现点击左右运动的方法
2015/04/10 Javascript
VueJs组件prop验证简单介绍
2017/09/12 Javascript
react-router 路由切换动画的实现示例
2018/12/03 Javascript
JavaScript实现捕获鼠标坐标
2020/04/12 Javascript
如何利用 JS 脚本实现网页全自动秒杀抢购功能
2020/10/12 Javascript
在vue项目中 实现定义全局变量 全局函数操作
2020/10/26 Javascript
python简单获取数组元素个数的方法
2015/07/13 Python
简单实现python进度条脚本
2017/12/18 Python
详解python的ORM中Pony用法
2018/02/09 Python
Python装饰器用法示例小结
2018/02/11 Python
Python进阶之自定义对象实现切片功能
2019/01/07 Python
详解用python自制微信机器人,定时发送天气预报
2019/03/25 Python
Python 分享10个PyCharm技巧
2019/07/13 Python
python 使用socket传输图片视频等文件的实现方式
2019/08/07 Python
python对Excel按条件进行内容补充(推荐)
2019/11/24 Python
python mock测试的示例
2020/10/19 Python
Opencv 图片的OCR识别的实战示例
2021/03/02 Python
今天学到的CSS最新技术(与图片背景相关)
2012/12/24 HTML / CSS
美国家用和厨房电器销售网站:Appliances Connection
2020/01/24 全球购物
股权转让协议书
2014/04/12 职场文书
小学见习报告
2014/10/31 职场文书
音乐教师个人总结
2015/02/06 职场文书
不同意离婚代理词
2015/05/23 职场文书
新郎结婚感言
2015/07/31 职场文书
2019年警察入党转正申请书最新范文
2019/09/03 职场文书
什么是SOLID
2022/03/24 Javascript
Ruby序列化和持久化存储 Marshal和Pstore介绍
2022/04/18 Ruby