`
zhouyrt
  • 浏览: 1125539 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

JavaScript中两种类型的全局对象/函数

阅读更多

 

这里所说的JavaScript指浏览器环境中的包括宿主环境在内的。第一种是ECMAScript Global Object,第二种是宿主环境(Host)下的全局对象/函数。

一、核心JavaScript内置对象,即ECMAScript实现提供的不依赖于宿主环境的对象。

 

这些对象在程序执行之前就已经(实例化)存在了。ECMAScript称为The Global Object,分为以下几种

 

1, 值属性的全局对象(Value Properties of the Global Object)。有NaN,Infinity,undefined。

2, 函数属性的全局对象(Function Properties of the Global Object)。有eval,parseInt,parseFloat,isNaN,isFinite,decodeURI,encodedURI,encodeURIComponent

3,构造器(类)属性的全局对象(Constructor Properties of the Global Object)。有Object,Function,Array,String,Boolean,Number,Date,RegExp,Error,EvalError,RangeError,ReferenceError,SyntaxError,TypeError,URIError。

4,其它属性的全局对象(Other Properties of the Global Object),可以看出成是Java中的静态类,可以直接用类名+点号+方法名使用。有Math,JSON。

 

 

ECMAScript规范提到这些全局对象(The Global Object)是具有Writable属性的,即Writable为true,枚举性(Enumerable)为false,即不能用for in枚举。ECMAScript有这么一段

 

Unless otherwise specified, the standard built-in properties of the global object have attributes {[[Writable]]: true, [[Enumerable]]: false, [[Configurable]]: true}.

 

 

虽然规范提到The Global Object是可以被重写的,但不会有谁去重写它们的。这里仅仅做个测试。

 

NaN    = 11;
eval   = 22;
Object = 33;
Math   = 44;

alert(NaN);
alert(eval);
alert(Object);
alert(Math);

 

分别取值属性的全局对象, 函数属性的全局对象,构造器(类)属性的全局对象,其它属性的全局对象NaN,eval,Object,Math。结果如下:

 

  IE6/7/8 Firefox/Chrome/Opera IE9/Safari
alert(NaN) 11 NaN
alert(eval) 22 22
alert(Object) 33 33
alert(Math) 44 44

 

 

 

 

 

 

 

 

 

 

结果可以看出除了NaN在IE9(pre3)/Safari不能被重写外,其它都被重写了。

这里只是列举了四个,感兴趣的可以将以上所有的The Global Object一一测试下。这里想表达的是核心JavaScript内置对象一般是可以被重写的 ,虽然没人这么干。

下面测试下其枚举性

 

for(var a in NaN){
	alert(a);
}
for(var a in eval){
	alert(a);
}
for(var a in Object){
	alert(a);
}
for(var a in Math){
	alert(a);
}
 

所有浏览器都没有弹出,即属性不被枚举。感兴趣的可以将以上所有的The Global Object的枚举性一一测试下。
当然对于有些浏览器如Firefox,某些Global Object被重写后又是可以被枚举的。

 

二、宿主环境提供的全局对象/函数 。

 

如window,alert,setTimeout,document,location等,多数浏览器都会限制其重写,如

window = 55;
alert(window);

 

该句在IE下会出错提示非法复制,后面的弹出框没有执行。其它浏览器则当window=55不存在,仍然弹出了window。


再重写下alert

 

alert = 55;
console.log(alert);

 

IE下提示报错,Firefox/Chrome/Safari/Opera竟然被重写了,从对应的控制台可以看到输出了55。可以看出对于宿主环境提供的全局对象/函数,有的浏览器不支持重写,有的则可以重写

以下是两种方式声明全局变量

 

a1 = 11;
var a2 = 22;

for(a in window){
	if(a=='a1'||a=='a2'){
		alert(a)
	}
}
 

上述代码在IE中不会弹出信息框,在IE中如下

 

//IE
with(host_object){//window
	with(global_object){//Global
		a1 = 11;
		var a2 = 22;
	}	
}
 

即a1,a2是作为上面说的第一种,JS引擎提供的Global对象上的属性,而非第二种宿主环境提供的window对象上的属性。因此IE中for in window时a1,a2都不存在。如果IE中提供对象Global对象的引用,没准下面的代码可以弹出信息框。

 

for(a in Global){
	if(a=='a1'||a=='a2'){
		alert(a)
	}
}
 

在Firefox/Safari/Chrome/Opera中大概是下面的样子

 

//Firefox/Safari/Chrome/Opera
with(host_object){//window
	a1 = 11;
	var a2 = 22;
	with(global_object){//Global
	}	
}
 

即a1,a2是作为上面说的第二种,宿主环境提供的全局对象window上的属性。因此for in window时a1,a2都存在,弹出了信息框。

 

再看第三者方式声明全局变量window.a3 = 33,这样是显示的把a3挂在window上作为window的属性,因此在所有浏览器中for in window时都能获取到a3。

 

 

PS: http://snandy.iteye.com/blog/720816

分享到:
评论
3 楼 tanxiangbo 2010-08-09  
我还是没有搞清楚为什么a1 in window时在IE下又true了。

确实是个问题!
2 楼 zhouyrt 2010-07-31  
To:tanxiangbo

我还是没有搞清楚为什么a1 in window时在IE下又true了。
1 楼 tanxiangbo 2010-07-30  
恩,LZ研究的很细致!很好!学习了!
一直希望搞清楚js的运行环境。我所指的是运行时的内存情况,就象java虚拟机哪样描述的很清晰!

相关推荐

    浅析JavaScript中两种类型的全局对象/函数

    主要介绍了JavaScript中两种类型的全局对象/函数。需要的朋友可以过来参考下,希望对大家有所帮助

    浅析javascript中函数声明和函数表达式的区别

    javascript中声明函数的方法有两种:函数声明式和函数表达式. 区别如下: 1).以函数声明的方法定义的函数,函数名是必须的,而函数表达式的函数名是可选的. 2).以函数声明的方法定义的函数,函数可以在函数声明之前调用,...

    【JavaScript源代码】配置vue全局方法的两种方式实例.docx

    配置vue全局方法的两种方式实例  目录 1,前言 2,第一种方式 3,第二种方式 总结 1,前言  2,第一种方式  3,第二种方式  总结 1,前言  在Vue项目开发中,肯定会有这样一个场景:在不同的组件页面用到...

    浅谈javascript 函数表达式和函数声明的区别

    javascript中声明函数的方法有两种:函数声明式和函数表达式. 区别如下: 1).以函数声明的方法定义的函数,函数名是必须的,而函数表达式的函数名是可选的. 2).以函数声明的方法定义的函数,函数可以在函数声明之前调用,...

    jQuery权威指南-源代码

    6.1.4 jQuery中的全局函数getScript()/166 6.1.5 jQuery中异步加载XML文档/168 6.2 请求服务器数据/170 6.2.1 $.get()请求数据/170 6.2.2 $.post()请求数据/172 6.2.3 serialize()序列化表单/175 6.3 $.ajax...

    javascript学习笔记.docx

    b) 实例方法:在构造函数中把原型对象中的一个属性设为函数来实现。 c) 类属性:构造函数本身的属性。 d) 类方法:用合适的函数作为构造函数本身的一个属性。 e) 子类:把原型对象赋值为父类的一个实例,默认父类为...

    【JavaScript源代码】详解JavaScript闭包问题.docx

    详解JavaScript闭包问题  闭包是纯函数式编程语言的传统特性之一。...变量的作用域分为两种:全局变量和局部变量。 var n = 999; //全局变量 function f1() { a = 100; //在这里a也是全局变量 alert(n); } 

    javascript中局部变量和全局变量的区别详解

    javascript有两种变量:局部变量和全局变量。当然,我们这篇文章是帮助大家真正的区别这两种变量。 首先,局部变量是指只能在本变量声明的函数内部调用。全局变量时整个代码中都可以调用的变量。当然,单单从字面上...

    javascript初级代码学习.zip

    001-HTML中嵌入JavaScript代码的第一种方式 002-HTML中嵌入JavaScript代码的第二种方式 003-HTML中嵌入...008-JS中的数据类型 014-null NaN undefined这三个值有什么区别 015-JS的常用事件-注册事件的两种方式

    javascript类型系统 Window对象学习笔记

    所有在全局作用域中定义的属性和函数都是window对象的属性 var myStringVar = 'myString'; var myFunctionVar = function(){}; console.log('myStringVar' in window);//true console.log('myFunctionVar' in ...

    JavaScript经典实例

     1.2连接字符串和另一种数据类型  1.3条件比较字符串  1.4在字符串中查找子字符串  1.5从一个字符串提取子字符串  1.6检查一个存在的、非空的字符串  1.7将一个关键字字符串分解为单独的关键字  1.8插入特殊...

    JavaScript笔记

    JavaScript:定义行为和动作 (基于对象和事件驱动的客户端脚本语言;也是一种广泛应用于客户端Web开发的脚本语言) 基于对象:网页中的一切...22.全局函数:不用任何对象点(.)就可以调用--可用于所有的 JavaScript ...

    javascript的this关键字详解

     因此可将 this 的剖析分为“全局环境” 和 “函数环境” 两种类型的环境对象 全局环境 console.log(this === window); // true var a = 10; console.log(this.a); // 10 函数环境 在函数内部,this 的取值取决于...

    javascript闭包的理解

    变量的作用域分两种:全局变量和局部变量。没有定义到任何函数中的变量为全局变量,在函数中定义的变量为局部变量,注意在函数内部定义变量时一定要使用var关键字,不带var关键字的变量为全局变量。 javascript中每...

    javascript帮助文档 参考技术

    JScript 是 Microsoft 公司对 ECMA 262 语言规范(ECMAScript 编辑器 3)的一种实现。除了少数例外(为了保持向后兼容),JScript 完全实现了 ...Jscript 支持两种函数:一类是语言内部的函数,另一类是自己创建的。

    JavaScript中的eval()函数使用介绍

    是JavaScript全局对象的一个函数。比如,上述代码等价于: 代码如下: console.log(this.eval(“42 * 2”));//84 不过在使用eval()语句时,一般都采用上述第一种做法,也即忽略全局对象直接使用...

    JavaScript的类型、值和变量小结

    前言:JavaScript的数据类型分为两类:原始类型和对象类型。5种原始类型:数字、字符串、布尔值、null(空)、undefined(未定义)。对象是属性的集合,每个属性都由“名/值对”(值可以是原始值、也可以是对象)...

    javascript中的作用域和闭包详解

    JavaScript变量实际上只有两种作用域,全局变量和函数的内部变量。在函数内部任何一个地方定义的变量(var scope)其作用域都是整个函数体。 全局变量:指的是window对象下的对象属性。 作用域划分:基于上下文,以...

    简单了解JavaScript作用域

    在 JavaScript 中,有两种类型的作用域:全局和局部作用域。 全局作用域 第一种作用域是全局作用域。它很容易定义。如果一个变量或函数是_全局的_,那么在程序中的任何地方都可以访问到它们。在浏览器中,全局作用域...

Global site tag (gtag.js) - Google Analytics