登录
首页 >  文章 >  前端

let、var 或 const 之间有什么区别?

来源:dev.to

时间:2024-08-22 09:09:56 130浏览 收藏

从现在开始,我们要努力学习啦!今天我给大家带来《let、var 或 const 之间有什么区别?》,感兴趣的朋友请继续看下去吧!下文中的内容我们主要会涉及到等等知识点,如果在阅读本文过程中有遇到不清楚的地方,欢迎留言呀!我们一起讨论,一起学习!

let、var 或 const 之间有什么区别?

使用 var 关键字声明的变量的作用域为创建它们的函数,或者如果在任何函数外部创建,则为全局对象。 let 和 const 是块作用域的,这意味着它们只能在最近的一组花括号(函数、if-else 块或 for 循环)内访问。

function foo() {
  // all variables are accessible within functions.
  var bar = 'bar';
  let baz = 'baz';
  const qux = 'qux';

  console.log(bar); // bar
  console.log(baz); // baz
  console.log(qux); // qux
}

console.log(bar); // referenceerror: bar is not defined
console.log(baz); // referenceerror: baz is not defined
console.log(qux); // referenceerror: qux is not defined

if (true) {
  var bar = 'bar';
  let baz = 'baz';
  const qux = 'qux';
}

// var declared variables are accessible anywhere in the function scope.
console.log(bar); // bar
// let and const defined variables are not accessible outside the block they were defined in.
console.log(baz); // referenceerror: baz is not defined
console.log(qux); // referenceerror: qux is not defined

var 允许变量被提升,这意味着它们可以在声明之前在代码中引用。 let 和 const 不会允许这样做,而是会抛出错误。

console.log(foo); // undefined

var foo = 'foo';

console.log(baz); // referenceerror: can't access lexical declaration 'baz' before initialization

let baz = 'baz';

console.log(bar); // referenceerror: can't access lexical declaration 'bar' before initialization

const bar = 'bar';

用var重新声明变量不会报错,但let和const会报错

var foo = 'foo';
var foo = 'bar';
console.log(foo); // "bar"

let baz = 'baz';
let baz = 'qux'; // uncaught syntaxerror: identifier 'baz' has already been declared

let 和 const 的区别在于 let 允许重新分配变量的值,而 const 则不允许。

// This is fine.
let foo = 'foo';
foo = 'bar';

// This causes an exception.
const baz = 'baz';
baz = 'qux';

今天关于《let、var 或 const 之间有什么区别?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

声明:本文转载于:dev.to 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>