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 相关文章推荐
js jquery做的图片连续滚动代码
Jan 06 Javascript
基于jquery的direction图片渐变动画效果
May 24 Javascript
javascript中万恶的function实例分析
May 25 Javascript
用jquery仿做发微博功能示例
Apr 18 Javascript
JavaScript获取并更改input标签name属性的方法
Jul 02 Javascript
javascript中的altKey 和 Event属性大全
Nov 06 Javascript
jQuery代码性能优化的10种方法
Jun 21 Javascript
Angularjs中的ui-bootstrap的使用教程
Feb 19 Javascript
微信公众号生成新浪短网址的实现(快速生成)
Aug 18 Javascript
vue单应用在ios系统中实现微信分享功能操作
Sep 07 Javascript
详解Java中String JSONObject JSONArray List转换
Nov 13 Javascript
Vue中Object.assign清空数据报错的解决方案
Mar 03 Vue.js
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 5.3新增魔术方法__invoke概述
2014/07/23 PHP
PHP序列化操作方法分析
2016/09/28 PHP
php 字符串中是否包含指定字符串的多种方法
2018/04/12 PHP
在phpstudy集成环境下的nginx服务器下配置url重写
2019/12/02 PHP
JavaScript判断窗口是否最小化的代码(跨浏览器)
2010/08/01 Javascript
通过Jquery遍历Json的两种数据结构的实现代码
2011/01/19 Javascript
实现51Map地图接口(示例代码)
2013/11/22 Javascript
jquery查找父元素、子元素(个人经验总结)
2014/04/09 Javascript
js函数模拟显示桌面.scf程序示例
2014/04/20 Javascript
KVM虚拟化技术之使用Qemu-kvm创建和管理虚拟机的方法
2016/10/05 Javascript
Bootstrap输入框组件使用详解
2017/06/09 Javascript
解决Vue watch里调用方法的坑
2020/11/07 Javascript
[00:48]完美“圣”典2016风云人物:xiao8宣传片
2016/11/30 DOTA
python共享引用(多个变量引用)示例代码
2013/12/04 Python
Python计算一个文件里字数的方法
2015/06/15 Python
python脚本内运行linux命令的方法
2015/07/02 Python
Win10下python3.5和python2.7环境变量配置教程
2018/09/18 Python
django的ORM模型的实现原理
2019/03/04 Python
Python3基础教程之递归函数简单示例
2019/06/07 Python
python urllib爬虫模块使用解析
2019/09/05 Python
python序列类型种类详解
2020/02/26 Python
pycharm中导入模块错误时提示Try to run this command from the system terminal
2020/03/26 Python
Python三维绘图之Matplotlib库的使用方法
2020/09/20 Python
python 多线程爬取壁纸网站的示例
2021/02/20 Python
HTML5 预加载让页面得以快速呈现
2013/08/13 HTML / CSS
html5 canvas fillRect坐标和大小的问题解决方法
2014/03/26 HTML / CSS
应用服务器有那些
2012/01/19 面试题
C语言50道问题
2014/10/23 面试题
银行财务部实习生的自我鉴定
2013/11/27 职场文书
施工资料员岗位职责
2014/01/06 职场文书
管理专员自荐信
2014/01/26 职场文书
《秋姑娘的信》教学反思
2014/02/28 职场文书
大型演出策划方案
2014/05/28 职场文书
怎样写家长意见
2015/06/04 职场文书
师范生小学见习总结
2015/06/23 职场文书
Java中使用Filter过滤器的方法
2021/06/28 Java/Android