• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

JavaScript中var let const的用法有哪些区别

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

1.重复声明

var支持重复声明,let、const不支持重复声明。

1.1 var

var a = 1;
var a = 2;
console.log(a);

输出结果:

2

1.2 let

let b = 3;
let b = 4;
console.log(b);

输出结果:

Uncaught SyntaxError: Identifier 'b' has already been declared

1.3 const

const c = 5;
const c = 6;
console.log(c);

输出结果:

Uncaught SyntaxError: Identifier 'c' has already been declared

2.变量提升

var支持变量提升,但是只提升声明不提升值。let、const不支持变量提升。

2.1 var

a=2;
console.log(a);
var a = 1;

输出结果:

2

2.2 let

a=2;
console.log(a);
let a = 1;

输出结果:

Uncaught ReferenceError: Cannot access 'a' before initialization at index.html:28

2.3 const

a=2;
console.log(a);
const a = 1;

输出结果:

Uncaught ReferenceError: Cannot access 'a' before initialization at index.html:28

3.暂时性死区

var不存在暂时性死区,let、const存在暂时性死区。
只要作用域内存在let、const,它们所声明的变量或常量就自动“绑定”在这个区域,不再受外部作用域影响。

3.1 var

var a = 1;
function fun() {
    console.log(a);
    var a = 2;
}
fun();

输出结果:

undefined

3.2 let

let a = 1;
function fun() {
    console.log(a);
    let a = 2;
}
fun();

输出结果:

Uncaught ReferenceError: Cannot access 'a' before initialization

3.3 conset

let a = 1;
function fun() {
    console.log(a);
    const a = 2;
}
fun();

输出结果:

Uncaught ReferenceError: Cannot access 'a' before initialization

4. window对象的属性和方法

全局作用域中,var声明的变量、通过function声明的函数,会自动变成window对象的属性和方法。

var a = 1;
function add() { };
console.log(window.a === a);
console.log(window.add === add);

输出结果:

true
true

5.块级作用域

var没有块级作用域,let、const有块级作用域。
使用var在for循环中定义变量i:

for (var i = 0; i < 3; i++) {
    // console.log(i);
}
console.log(i);

输出结果:

3

使用let在for循环中定义变量i:

for (let i = 0; i < 3; i++) {
    // console.log(i);
}
console.log(i);

输出结果:

Uncaught ReferenceError: i is not defined

到此这篇关于JavaScript中var let const的用法有哪些区别的文章就介绍到这了,更多相关JavaScript var用法内容请搜索极客世界以前的文章或继续浏览下面的相关文章希望大家以后多多支持极客世界!


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
原生JS实现可拖拽登录框发布时间:2022-02-05
下一篇:
JavaScript函数中上下文有哪些规则发布时间:2022-02-05
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap