非严格模式下,函数的参数如果同名,会取第二个实参的值。

在严格模式下执行以下选项的程序,不会抛出异常的是()

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,没有报错

posted @ 2023-11-13 00:32  龙陌  阅读(20)  评论(0)    收藏  举报