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日

相关文章

  • js时间日期格式化封装函数

    下面我将详细讲解“js时间日期格式化封装函数”的完整攻略。 什么是时间日期格式化? 时间日期格式化就是将日期和时间类型的数据按照一定的格式进行展示,常见的格式有以下几种: 年月日时分秒:YYYY-MM-DD HH:mm:ss 年月日:YYYY-MM-DD 时分秒:HH:mm:ss 为什么要进行时间日期格式化? 在实际的开发中,时间日期的格式可能会影响到展示和…

    JavaScript 2023年5月27日
    00
  • JS数组方法slice()用法实例分析

    JS数组方法slice()用法实例分析 简介 slice() 方法返回一个新的数组对象,这个对象是由 begin 和 end 决定的原数组的浅拷贝。原数组不会被修改。常用于数组的复制或提取。 语法 array.slice(begin, end) 参数描述: begin:一个零开始的索引,提取起始处的元素。 end(可选):一个零开始的索引,提取终止处的元素。…

    JavaScript 2023年5月27日
    00
  • window.location.href的用法(动态输出跳转)

    关于window.location.href的用法,先来介绍一下它的基本概念。 window.location.href是一个引用当前页面的URL字符串,它可以动态地改变页面的路径,实现页面的跳转。通过设置window.location.href的值,可以让当前页面跳转到指定的URL地址。 以下是window.location.href的一些常见应用场景: …

    JavaScript 2023年6月11日
    00
  • JavaScript实现计算多边形质心的方法示例

    计算多边形质心的基本原理 在计算多边形质心之前,我们需要先了解计算质心的基本原理。 计算多边形质心的基本原理:多边形质心(又称为重心、形心)是该多边形所有点的坐标分别加权平均的结果,其中每个点的权重为这个点与多边形重心连线长度的平方与多边形面积的乘积(因此称为“权面积”)。 JavaScript实现计算多边形质心的方法示例 下面提供两种JavaScript实…

    JavaScript 2023年5月28日
    00
  • iView UI FORM 动态添加表单项校验规则写法实例

    iView UI是一个基于Vue.js的UI组件库,提供了众多的组件和功能,其中FORM组件是表单组件,可以方便的实现表单的校验和提交。 当需要动态添加表单项时,需要动态绑定表单项的校验规则。下面是iView UI FORM动态添加表单项校验规则的完整攻略: 步骤一:引入iView UI组件库 import Vue from ‘vue’ import iVi…

    JavaScript 2023年6月10日
    00
  • document.getElementById为空或不是对象的解决方法

    问题背景 在web开发中,常常使用到document.getElementById()方法来获取特定的DOM元素。但有时候会因为各种原因而出现document.getElementById为空或不是对象的错误提示,让开发者很苦恼,并且无法正常运行。 问题原因 造成该错误提示的原因很多,最常见的有以下几种: 当DOM元素尚未加载进页面时尝试获取 DOM元素的I…

    JavaScript 2023年6月10日
    00
  • javascript学习笔记(十五) js间歇调用和超时调用

    JavaScript学习笔记(十五)—— JS间歇调用和超时调用 JavaScript中的间歇调用和超时调用是处理异步编程中的常用技术,它们可以让我们在指定的时间间隔内执行指定的函数或代码块。接下来我们将详细讲解 JavaScript中的间歇调用和超时调用。 1. setInterval方法 setInterval方法可以按照指定时间间隔重复执行指定的函数或…

    JavaScript 2023年5月27日
    00
  • 向fckeditor编辑器插入指定代码的方法

    关于向Fckeditor编辑器插入指定代码的方法,可以分为以下两种方式: 一、在源码视图中添加指定代码 步骤如下: 打开Fckeditor编辑器,点击源码视图按钮; 在源码视图中添加你的代码段,注意代码段必须符合HTML标准; 回到正常视图,此时你的代码段会被正确渲染出来。 以下是一个示例代码,添加了一个带有样式的Button按钮: <button s…

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