1.
if (!("a" in window)) { var a = 1; } alert(a);
答案是undefined。首先js会把全部全局的变量提前。所以此题能够改动为
var a;
if(!("a" in window)){
a = 1;
}
alert(a);
第二点:全部的全局变量都是window的属性,所以if推断是不会进去的,因此a的值是undefined
假设把第一个样例的var去掉,答案就是1,为什么呢。由于a没有声明,因此不存在与window对象里面,然后就进入if推断了
2.
var a = 1, b = function a(x) { x && a(--x); }; alert(a);
答案是1;首先要知道变量的声明和函数的声明都会提前,第二:函数的声明会覆盖变量的声明。样例:
function value(){ return 1; } var value; alert(typeof value); //"function"可是假设变量已经被赋值则会相反:
function value(){ return 1; } var value = 1; alert(typeof value); //"number"因此答案就非常明显了。
3.
function a(x) { return x * 2; } var a; alert(a);
依据第2道题能够得出答案是function a(x){return x * 2}
4.
function b(x, y, a) {
arguments[2] = 10;
alert(a);
}
b(1, 2, 3);
arguments什么的真的好玄乎。此题答案是10,这个是比較简单的,arguments和传进去的參数尽管指向了两个空间,可是值是能够同步的。
可是当传进去的參数小于须要传的參数时。值就无法完毕同步:
function b(x, y, a) {
arguments[2] = 10;
alert(a);
}
b(1, 2);
答案是undefined。由于和a没关系。可是假设是以下的样例
function b(x, y, a) {
arguments[2] = 10;
alert(arguments[2]);//答案是10
}
b(1, 2);
5.
function a() { alert(this); } a.call(null);
答案是window,这里面须要知道,call传进去的第一个參数是要指向的对象,可是假设是null或者undefined的话,this则指向window