【Web前端问题】参数变量是默认声明的,所以不能用let或const再次声明,但是为什么可以使用var声明?

正常情况下let或者const声明的变量,是不能在重复声明的,即使是使用var也会报错,
eg:

let a = 123;

var a = 456;

错误提示:Uncaught SyntaxError: Identifier 'a' has already been declared

const C = 123;

var C = 456;

错误提示:Uncaught SyntaxError: Identifier 'a' has already been declared

参数变量是默认声明的,所以不能用let或const再次声明,

但是为什么可以使用var声明? 这里的默认声明是指什么?

eg:
函数内使用var声明参数

function foo(x = 5, y = function() { x = 2; }) {

var x = 3;

y();

console.log(x);

}

foo() // 不会报错

函数内使用let声明参数

function foo(x = 5, y = function() { x = 2; }) {

  let x = 3;

y();

console.log(x);

}

foo() // 会报错 Uncaught SyntaxError: Identifier 'x' has already been declared

回答:

Ecmascript 标准就是这样定的。

回答:

//不报错

var a = "123";

var a = "321";

//报错

var a = "123";

let a = "321";

回答:

function foo(x = 5, y = function () { x = 2; }) {

let x = 3;

// y();

console.log(x);

}

foo();

即使函数不调用,结果也是一样的。函数参数变量是默认声明的,所以不可以使用let和const再次声明,其与第一种情况类似。
关于let和const的说明可以参考阮一峰es6中的函数的扩展

回答:

function foo(x = 5, y = function() { x = 2; }) {

let x = 3;

y();

console.log(x);

}

foo()

这里报错,我感觉应该是函数声明的提升,所以应该他是先执行了y(); 所以已经注册了一个x,后面再执行let x=3的时候 ,就会报错。不知道 我的理解有没有错。 他x的赋值应该是 5 2 最后才是let x= 3中报错。

回答:

我也是今天看阮一峰的《ES6标准入门》函数扩展章节中看到这段代码的,同样很疑惑,在章节中作者说的是函数参数.png,我就更加疑惑了,怎么会是不同作用域,我现在就只记住,凡是用var再次声明参数变量,此时var声明的变量和参数变量不是同一个变量,在函数体内直接访问该变量是访问var声明的变量

以上是 【Web前端问题】参数变量是默认声明的,所以不能用let或const再次声明,但是为什么可以使用var声明? 的全部内容, 来源链接: utcz.com/a/142535.html

回到顶部