当前位置: 代码网 > it编程>编程语言>Javascript > javascript中var与let、const的区别详解

javascript中var与let、const的区别详解

2024年05月15日 Javascript 我要评论
一、var声明的变量会挂载在window上,而let和const声明的变量不会:var a = 100;console.log(a,window.a); // 100 100let b = 10

一、var声明的变量会挂载在window上,而let和const声明的变量不会:

var a = 100;
console.log(a,window.a);    // 100 100

let b = 10;
console.log(b,window.b);    // 10 undefined

const c = 1;
console.log(c,window.c);    // 1 undefined

二、var声明变量存在变量提升,let和const不存在变量提升

console.log(a); // undefined  ===>  a已声明还没赋值,默认得到undefined值
var a = 100;

console.log(b); // 报错:b is not defined  ===> 找不到b这个变量
let b = 10;

console.log(c); // 报错:c is not defined  ===> 找不到c这个变量
const c = 10;

三、let和const声明形成块作用域

if(1){
    var a = 100;
    let b = 10;
}

console.log(a); // 100
console.log(b)  // 报错:b is not defined  ===> 找不到b这个变量

if(1){

    var a = 100;
        
    const c = 1;
}
 console.log(a); // 100
 console.log(c)  // 报错:c is not defined  ===> 找不到c这个变量

四、同一作用域下let和const不能声明同名变量,而var可以

var a = 100;
console.log(a); // 100

var a = 10;
console.log(a); // 10
let a = 100;
let a = 10;

//  控制台报错:identifier 'a' has already been declared  ===> 标识符a已经被声明了。

五、暂存死区

var a = 100;

if(1){
    a = 10;
    //在当前块作用域中存在a使用let/const声明的情况下,给a赋值10时,只会在当前作用域找变量a,
    // 而这时,还未到声明时候,所以控制台error:a is not defined
    let a = 1;
}

六、const

/*
*   1、一旦声明必须赋值,不能使用null占位。
*
*   2、声明后不能再修改
*
*   3、如果声明的是复合类型数据,可以修改其属性
*
* */

const a = 100; 

const list = [];
list[0] = 10;
console.log(list);  // [10]

const obj = {a:100};
obj.name = 'apple';
obj.a = 10000;
console.log(obj);  // {a:10000,name:'apple'}

以上就是javascript中var与let、const的区别详解的详细内容,更多关于javascript中var与let、const的区别的资料请关注代码网其它相关文章!

(0)

相关文章:

  • 一文带你了解React中的并发机制

    一文带你了解React中的并发机制

    一、自动批处理react 现在可以自动将多个状态更新操作批量处理,以减少不必要的渲染和提高性能。这意味着,当你在一个事件处理程序中连续调用多个状态更新函数时,r... [阅读全文]
  • js异步处理方案之异步串行与异步并行

    js异步处理方案,js的异步串行与异步并行一、什么是串行,并行,并发串行:这个就像队列一样,一个执行完,下一个再执行,比如js同步执行并发:是指这个系统拥有处理多个任务的能力,在一…

    2024年05月15日 编程语言
  • 浅谈一下forward和redirect的区别

    浅谈一下forward和redirect的区别

    1.forward 和redirectforward又叫转发,表示转发,当请求来到时,可以将请求转发到其他的指定服务,用户端不知晓。redirect又叫重定向,... [阅读全文]
  • 浅谈一下JavaScript与C++的差异

    浅谈一下JavaScript与C++的差异

    在正式开始向各位前端开发者介绍 c++ 语言之前,我们先讨论一下 c++ 语言与 javascript 语言的差异(为了约束讨论的范围,这里就不提 html 和... [阅读全文]
  • JavaScript 之JS的组成与基本语法

    javascriptjs 主要是用来开发前端, 但是也可以做别的. js 现在是一个 “通用” 的编程语言.网页开发 (做各种特效)网页游戏服务器端开发js…

    2024年05月15日 编程语言
  • Rust中Trait的使用

    Rust中Trait的使用

    概述在rust中,trait是一个核心概念,它允许我们定义类型应该具有的行为。trait类似于其他语言中的接口,但rust的trait更为强大和灵活。它不仅定义... [阅读全文]

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com