首页 > 代码库 > JavaScript你所不知道的困惑(1)

JavaScript你所不知道的困惑(1)

困惑一:

先看一个例子:

function test(){
	message = "hi";
}
test();
alert(message);
会输出字符串“hi"

在函数内部使用var定义的变量是局部变量,省略var操作符的变量是全局变量。

困惑二:

alert(undefined == null)
结果是”true"

我们知道在js中分为基本类型和引用类型,基本类型包括number、string、boolean、undefined、null.如果一个基本类型没有初始化则会是undefined类型,而null代表空指针。实际上undefined值是派生自null的,因此返回true.

困惑三:

alert(isNaN(NaN));   //true
alert(isNaN(10));    //false
alert(isNaN("10"));    //false  自动类型转换
alert(isNaN("blue"));   //true
alert(isNaN(true));    //false  自动类型转换
NaN指非数值(Not a Number)是一个特殊的数值,在ECMAScript中,任何数值除以0返回NaN,而且任何涉及NaN的操作都会返回NaN. NaN与任何值不等,包括自身。

alert(NaN == NaN);  // false 
困惑四:

for(var propName in window){
	document.write(propName);
}
For - in 语句是一种精准的迭代语句,可以用来枚举对象的属性,类似于java中的for( String s : String[])

困惑五:

var qs = location.search.substring(1);
var hostName = location.hostname;
var url = location.href;

//等价于下面

with(location){
	var qs = search.substring(1);
	var hostName = hostname;
	var url = href;
}
with语句的作用是将代码的作用域设置到一个特定的对象中,主要目的是为了简化多次编写同一个对象的工作。

困惑六:

function howManyArgs(){
	alert(arguments.length);
}

howManyArgs("String", 45);  //2
howManyArgs();  //0
howManyArgs(12);   //1
ECMAScript中的参数在内部是用一个数组来表示的,函数接收到的始终都是这个数组,而不关心数组中包含哪些参数(如果没有参数的话)。

命名的参数只提供便利,但不是必须的。再看下面例子

function doAdd(num1, num2){
	arguments[1] = 10;
	alert(arguments[0] + num2);
}
因为arguments对象中的值会自动反映到对应的命名参数,所以num2会变成10,但是他们的内存空间是独立的(不是引用),另外arguments对象的长度是由传入的参数个数决定的,不是由定义函数时的命名参数个数决定的。

困惑七:

for(var i=0; i<10; i++){
	
}
alert(i);   //输出结果为 10
JavaScript没有块级作用域。