为什么可以在 Chrome 的 devtools 控制台中重新声明'let'?(其他浏览器不允许这样做。



我正在学习ES6中引入的备用变量声明。现在,我了解到"let"变量声明是块范围的,尽管它可以更新,但不能在同一范围内重新声明。

我的第一个问题是:以上信息是真的吗?我正在阅读2020年4月2日的一篇文章。事情可能已经改变了。

我的第二个问题是:如果以上信息是真的,那么当我运行时,如何在我的Chrome控制台中

let greeting = 'hello';

下面一行我重新声明为

let greeting = 'say hi now';

该值更改为"立即问好">并且没有错误报告。

我想这与行尾的分号有关,但不确定。这里只是一个JS小人物。谢谢

这是谷歌Chrome的特定功能

支持控制台中的let和类重新声明

控制台现在支持letclass语句的重新声明。对于使用控制台来试验新JavaScript代码的web开发人员来说,无法重新声明是一个常见的烦恼。

在实验中,我发现IE 11和Edge的行为与Chrome相同,因为分别键入每个命令不会产生错误,但在一次评估中执行这两个命令会产生错误。

另请参阅https://bugs.chromium.org/p/chromium/issues/detail?id=1004193


其他实验表明Firefox和NodeJS REPL没有提供这样的功能。

最新更新