非严格模式下,函数的参数如果同名,会取第二个实参的值。
在严格模式下执行以下选项的程序,不会抛出异常的是()
A
uname = 'window';
setTimeout(function(){
console.log(this.uname)
},1000);
B
var uname = 'window';
(function(){console.log(this.uname)}());
C
function fn(a,a){
console.log(a+a);
}
fn(1,1);
D
var uname = 'window'
function Person(){console.log(this.uname);}
var p = new Person();
正确答案:D
A选项,在严格模式下,虽然定时器函数的this仍然指向window对象,但是变量uname必须先声明再赋值;
B选项,在严格模式下,立即执行函数的this取决于上下环境,这里指向undefined,由于没有uname属性,同样会抛出异常;
C选项,在严格模式下,函数不允许重名参数;
D选项,构造函数的this指向实例对象p,由于p没有uname属性,因此输出undefined。
选项A:
1)uname = 'window' 抛出错误:在严格模式下,给未声明的变量赋值,会导致抛出ReferenceError,报错
简而言之,严格模式下变量必须用关键字声明后才能使用
2)严格模式下,普通函数的this指向undefined
3)严格模式下,立即执行函数的this指向undefined
4)严格模式下,setTimeout中函数的this指向的window(与普通函数不同)
选项B:
严格模式下,立即执行函数的this指向的是undefinded,所以undefinded.uname当然会报错
选项C:
严格模式下,函数的参数不能同名,否则报错
非严格模式下,函数的参数如果同名,会取第二个实参的值。
选项D:
严格模式下:构造函数的this指向undefined,但是构造函数实例化对象的this指向的是实例化对象本身
构造函数实例化对象的this指向的是实例化对象本身,而实例化对象下没有uname这个属性,所以得到undefined,没有报错