Js中var,let,const的区别你知道吗

当我们在 JavaScript 中声明变量时,可以使用三种关键字 var、let 和 const。这些关键字虽然能够完成相同的任务,但它们的含义和用法是不同的。

var关键字

使用 var 关键字,我们可以在 JavaScript 中声明一个变量。它是 ES5 标准中的一部分。var 关键字在声明变量时,会将该变量提升到函数或全局作用域的顶部。这意味着,在声明之前,变量就已经存在了。同时,var 声明的变量在同一个作用域中可以被重复声明,这样会覆盖已有的变量值。

示例

function example() {
  var x = 10;
  if(true) {
    var x = 20;
    console.log(x); // 20
  }
  console.log(x); // 20
}
example();

上面的代码中,我们在函数中通过 var 声明了一个变量 x,并将其值设置为 10。然后,在 if 语句中,我们通过 var 重新声明了一个同名变量 x,并将其值设置为 20。当代码执行到 console.log(x) 时,会输出变量 x 的值,即 20。同时,如果我们在 if 语句的外部再次调用 console.log(x),它仍然会输出 20。这是因为使用 var 声明的变量在整个函数范围内都是可见的。

let 关键字

let 也是 ES6 标准中新增的关键字之一。相比于 var 来说,let 声明的变量的作用域与 var 声明的变量不同。在同一个作用域内,使用 let 声明的变量值不会相互干扰。同时,使用 let 声明变量时,变量只在当前代码块中有效,离开这个代码块后,变量就会销毁。

示例

function example() {
  let x = 10;
  if(true) {
    let x = 20;
    console.log(x); // 20
  }
  console.log(x); // 10
}
example();

上面的代码中,我们在函数中通过 let 声明了一个变量 x,并将其值设置为 10。然后,在 if 语句中,我们通过 let 重新声明了一个同名变量 x,并将其值设置为 20。当代码执行到 console.log(x) 时,会输出变量 x 的值,即 20。但是,当代码执行到 if 语句外部时,调用 console.log(x) 时会输出 10,这是因为外部代码块中的变量 x 不受内部代码块声明的 let 变量影响。

const 关键字

const 也是 ES6 标准中新增的关键字之一。使用 const 关键字,我们可以声明常量,这意味着变量的值在初始化之后不能被修改。和 let 一样,使用 const 声明的变量只在当前代码块中有效。

示例

function example() {
  const x = 10;
  x = 20; // 抛出 TypeError 异常,因为常量 x 的值不能再次修改
  if(true) {
    const x = 20;
    console.log(x); // 20
  }
  console.log(x); // 10
}
example();

上面的代码中,我们在函数中通过 const 声明了一个常量 x,并将其值设置为 10。然后,我们试图将常量 x 的值修改为 20,这时就会抛出 TypeError 异常。接着,在 if 语句中,我们通过 const 声明了一个同名常量 x,并将其值设置为 20。当代码执行到 console.log(x) 时,会输出变量 x 的值,即 20。但是,当代码执行到 if 语句外部时,调用 console.log(x) 时会输出 10,这是因为常量 x 的值不能再次修改。

总结来说,var 声明的变量作用于函数或全局作用域中,let 和 const 声明的变量作用于当前代码块中。let 和 const 声明的变量不能被重复声明,而 const 声明的变量的值一旦被设置后不能再次修改。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Js中var,let,const的区别你知道吗 - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • javascript之函数进阶详解

    JavaScript之函数进阶详解 函数的三种表现形式 JavaScript中的函数有三种表现形式:函数声明、函数表达式和箭头函数。其中,函数声明和函数表达式是最常见的形式。 函数声明 函数声明语法如下: function functionName(parameter1, parameter2, …parameterN) { // function bo…

    JavaScript 2023年5月18日
    00
  • 跟我学习javascript的循环

    跟我学习 JavaScript 的循环 JavaScript 中的循环语句可以让代码块重复执行多次,常用的循环语句有 for 循环、while 循环、do-while 循环等。本攻略将详细讲解 JavaScript 中的循环语句的使用方法。 for 循环 for 循环是最常用的循环语句之一,使用起来非常简便,可以按下面的方式进行: for (let i = …

    JavaScript 2023年5月18日
    00
  • JavaScript类的继承全面示例讲解

    JavaScript中的类继承是面向对象编程中的重要概念,它可以使得类与类之间实现代码的共享、重用以及扩展。在这里我们将详细讲解JavaScript类的继承全面示例讲解。 一、继承的概念 继承是指从已有的类中派生出新的类,新的类能够继承已有类的属性和方法,并且可以在此基础上添加自己的属性和方法。继承的概念可以使代码得到更好的复用性和灵活性。 二、JavaSc…

    JavaScript 2023年5月28日
    00
  • js取整数、取余数的方法

    下面是详细讲解“js取整数、取余数的方法”的完整攻略,希望能对您有所帮助。 取整数的方法 在Javascript中,我们可以使用以下方法来取整数部分: Math.floor() Math.floor()方法返回一个小于或等于给定数字的最大整数值。该方法向下舍入并返回值是比指定数字小的最大整数。 Math.floor(4.9); // 4 Math.floor…

    JavaScript 2023年5月27日
    00
  • javascript学习笔记(十二) RegExp类型介绍

    下面是关于“javascript学习笔记(十二) RegExp类型介绍”的完整攻略。 RegExp类型介绍 RegExp类型是JS语言中表示正则表达式的类型。正则表达式是一种用于模式匹配的工具,可以用来匹配字符串中的文本模式,在字符串的搜索、替换、切割等操作中特别方便。 创建RegExp实例 创建RegExp实例的两种方式: 字面量方式 javascript…

    JavaScript 2023年6月10日
    00
  • JavaScript事件对象event用法分析

    下面是关于JavaScript事件对象(event)的详细解析: 一、什么是JavaScript事件对象(event) 在JavaScript中,事件是当HTML文档中发生某些特定行为时所发生的结果。比如用户单击了一个按钮、鼠标移动到某一个元素上等交互行为。这些都可以被JavaScript捕捉到,并进行相应的处理。在这些事件中,事件对象(event)是事件发…

    JavaScript 2023年6月10日
    00
  • js 求时间差的实现代码

    要计算 JavaScript 中两个日期之间的时间差,可以使用 Date 对象。具体实现代码如下: const date1 = new Date(‘2021-08-01’); const date2 = new Date(‘2021-08-10’); const timeDiff = Math.abs(date2.getTime() – date1.getT…

    JavaScript 2023年5月27日
    00
  • js replace() 文本替换你所不知的

    接下来我将详细讲解一下 JavaScript 中的 replace() 方法,包括它的用法、语法、返回值、示例等内容。 replace() 方法的用途 在 JavaScript 中,replace() 方法是用来在一个字符串中查找指定值或正则表达式,并将匹配的部分替换为另一个指定的值或字符串。 replace() 方法的语法 replace() 方法的基本语…

    JavaScript 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部