`
zhouyrt
  • 浏览: 1141636 次
  • 性别: 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中的两类全局对象/函数,一类是ECMAScript内置的...

    JavaScript语言 变量、数据类型、对象、函数、作用域、事件、字符串.pdf

    - **概述**:JavaScript的数据类型分为两类:基本类型(值类型)和引用类型(对象类型)。 - **基本类型**:包括字符串(`string`)、数字(`number`)、布尔值(`boolean`)、`null`、`undefined`和`symbol`。 - *...

    javascript函数式编程

    在JavaScript中,纯函数避免了对全局变量的修改,使得代码更易于理解和测试。 2. **高阶函数**:高阶函数是接受一个或多个函数作为参数,或者返回一个函数的函数。JavaScript中的Array.prototype方法如`map`、`...

    Duktape导出全局对象文章代码

    在Duktape中,全局对象是JavaScript上下文中的顶级对象,它可以被用来存放自定义函数、变量和其他属性。将C/C++的对象或函数导出到这个全局对象,可以使得JavaScript能够直接调用和操作这些功能。这对于创建一个C/...

    JavaScript进阶:JS的全局变量和全局函数.docx

    全局变量和全局函数是JavaScript中两个基础且重要的概念。 全局变量是在函数外部声明的变量,可以在整个程序的任何地方被访问。它们在程序开始执行时被创建,并在整个程序生命周期内存在。JavaScript的全局变量有三...

    javascript函数速查手册

    函数有两种声明方式:函数声明和函数表达式。前者具有提升(hoisting)特性,后者则不会。例如: ```javascript // 函数声明 hello(); // 正常执行,无语法错误 function hello() { console.log('Hello!'); } // ...

    javascript函数速查

    JavaScript有两种作用域:全局作用域和函数作用域。在函数内部声明的变量仅在该函数内部可见。ES6引入了块级作用域,通过let和const关键字实现,但函数作用域仍然独立于块级作用域。 七、闭包 闭包是指函数可以访问...

    深化浅析JavaScript中的Function类型_.docx

    2. **函数定义方式**:JavaScript提供了两种主要的函数定义方式,即函数声明和函数表达式。函数声明会被提升到其所在作用域的顶部,可以在声明之前被调用;而函数表达式则必须等到解析器执行到相应的代码行才会被...

    面向对象javascript

    函数在JavaScript中是一种特殊的对象类型,可以作为值赋给变量、作为参数传递给另一个函数、或作为其它函数的返回值。函数对象可以具有arguments、caller和callee等属性。 在JavaScript中,我们可以使用函数的...

    JavaScript核心对象参考手册

    1. **全局对象Global**: JavaScript中的全局对象提供了许多内置函数,如`Math`(数学运算)、`Date`(日期和时间操作)、`JSON`(JSON解析和序列化)等。全局变量默认会成为全局对象的属性。 2. **对象创建与原型...

    javascript函数详解!

    JavaScript有两种作用域:全局作用域和局部作用域。函数内部声明的变量在函数内部可见,这就是局部作用域。全局变量在整个脚本或文件中都是可见的。 5. **闭包** 闭包是指函数可以访问并操作其外部作用域中的变量...

    JavaScript定义全局对象的方法示例

    在提供的代码示例中,展示了两种定义全局对象的方法: 1. **立即执行函数表达式(IIFE, Immediately Invoked Function Expression)**: ```javascript !function (factory) { factory(window['Hi'] = { __a: ...

    深入学习JavaScript中的函数

    函数可以被定义为一种特殊类型的对象,在JavaScript中,所有函数都是`Function`对象的实例。这意味着函数具有可变性,即可以被赋值给变量、作为参数传递给其他函数或者作为其他函数的返回值。 #### 函数声明与...

    即查即用-JavaScript核心对象参考手册.rar

    此外,函数是JavaScript代码的可重用块,可以有参数和返回值,函数表达式和函数声明是两种定义函数的方式,理解它们的区别对于编写高效代码很有帮助。 在JavaScript中,原型和原型链是实现继承的关键。每个对象都有...

    javascript函数

    在JavaScript中,有两种定义函数的方式:函数声明和函数表达式。 ##### 函数声明 函数声明是一种更直观的方法来定义函数,它的语法如下: ```javascript function functionName(parameters) { // function body } ...

    javascript 函数教程(由浅入深)

    - 全局函数在整个脚本中都可用,而局部函数只在其定义的范围内有效。 - 函数内部可以访问全局变量,但全局变量不能直接访问函数内部的局部变量。 8. **函数表达式**: - 除了函数声明外,还可以使用函数表达式,...

Global site tag (gtag.js) - Google Analytics