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

yizhihongxing

当我们在 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实现计时器秒表功能

    如果要使用 JavaScript 实现计时器秒表功能,需要遵循以下步骤: HTML 布局 首先,在 HTML 中创建一个容器用于显示计时器。这可以通过使用<div>元素创建。 <div id="timer">00:00:00</div> CSS 样式 为计时器设置样式,例如对齐方式、字体大小等。以下是一…

    JavaScript 2023年5月27日
    00
  • js时间戳与日期格式之间相互转换

    关于“js时间戳与日期格式之间相互转换的攻略”,我会从以下方面进行详细讲解: 时间戳和日期格式的概念及区别 时间戳转日期格式的方法 日期格式转时间戳的方法 示例说明 1. 时间戳和日期格式的概念及区别 时间戳是1970年1月1日(UTC/GMT的午夜)距离某一时间点的秒数,可以简单理解成整数形式的时间点。而日期格式则是指可读性较好的时间表示形式,例如“202…

    JavaScript 2023年5月27日
    00
  • JavaScript 正则表达式详解

    JavaScript 正则表达式详解 什么是正则表达式 正则表达式(Regular Expression)是一种用来描述、匹配一系列符合某个规律的字符串的表达式。在许多编程语言中,如JavaScript、Python、Java等,都支持正则表达式。 在JavaScript中,我们可以使用RegExp对象来创建正则表达式,并通过match、test等方法进行匹…

    JavaScript 2023年5月19日
    00
  • vue后台返回格式为二进制流进行文件的下载方式

    当我们在处理后台返回的文件下载数据时,有时候会遇到后台返回数据格式为二进制流的情况。这种格式的数据在前端界面上无法直接显示,需要通过特殊的处理方式进行文件下载。下面是完整攻略。 1. 后台设置content-type 第一步是需要后台在返回数据时设置content-type为“application/octet-stream”,这个content-type是…

    JavaScript 2023年6月11日
    00
  • JS数据类型判断的几种常用方法

    一、题目背景在JavaScript编程中,我们经常需要对数据的类型进行判断,以便进行不同的操作。本文详细讲解了JS数据类型判断的几种常用方法。 二、常用方法1. typeof 运算符这是最常用的判断数据类型的方式。它可以返回一个字符串,表示操作数的类型。它可以判断基本数据类型、“function”和“undefined”类型,但不能判断具体的引用类型。使用方…

    JavaScript 2023年5月27日
    00
  • 正则表达式进行页面表单验证功能

    正则表达式(Regular Expression)是一种处理字符串的强大工具,它可以用于字符串的匹配、搜索、替换和分割等操作。在网站制作过程中,利用正则表达式可以实现表单验证的功能,保证用户填写的数据符合规范。 以下是正则表达式进行页面表单验证的完整攻略: 确认需要验证的表单项,例如:用户名、密码、邮箱、手机号码等等 编写验证函数,将要验证的表单项和相应的正…

    JavaScript 2023年6月10日
    00
  • 全屏js头像上传插件源码高清版

    下面我将为你详细讲解“全屏js头像上传插件源码高清版”的完整攻略。 全屏js头像上传插件源码高清版 介绍 “全屏js头像上传插件源码高清版”是一款可供网页端使用的头像上传插件,能够帮助用户实现全屏界面下进行头像的上传。该插件基于Javascript语言进行开发,支持主流的浏览器(如Chrome、Firefox等)。 特点: 界面简洁、美观; 支持图片预览、拖…

    JavaScript 2023年6月11日
    00
  • JS 动态加载js文件和css文件 同步/异步的两种简单方式

    JS 动态加载js文件和css文件是Web开发中非常常见的操作。下面提供两种简单的方式来实现动态加载js文件和css文件,包括同步和异步的方式。 动态加载JS文件 同步加载JS文件 同步加载JS文件需要使用<script>标签,并设置async属性为false。这样就可以在JS文件加载完成之前暂停页面的解析和渲染,等待js文件加载完成之后再进行页…

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