这几天修改别人的js,发现声明变量有的用var,有的用let,那它们有什么区别呢?

javascript中声明变量的方式有:varletconst

1.var

(1)作用域:

  整个函数范围内,或者是全局的

function func() {
if (true) {
var str = 'hello world';
}
console.log(str);
}

输出:

hello world

(2)允许在相同作用域内重复声明同一个变量

var var1 = 'var1 first.';
var var1 = 'var1 second.';
console.log(var1);

输出:

  var1 second.

(3)var可以先使用,后声明

var1 = 'var1 first.';
var var1;
console.log(var1);

输出:

  var1 first.

(4)声明后未赋值

var var1;
console.log(var1);

输出:

  undefined

2.let

(1)作用域:

  只在let命令所在的代码块内({})有效

function func() {
if (true) {
let str = 'hello world';
}
console.log(str);
}

报错:

Uncaught ReferenceError: str is not defined

(2)不允许在相同作用域内重复声明同一个变量

let var1 = 'var1 first.';
let var1 = 'var1 second.';
console.log(var1);

报错:

  Uncaught SyntaxError: Identifier 'var1' has already been declared

(3)let必须先声明后使用

var1 = 'var1 first.';
let var1;
console.log(var1);

报错:

  Uncaught ReferenceError: var1 is not defined

(4)声明后未赋值

let var1;
console.log(var1);

输出

  undefined

3.const

const声明一个只读的常量

(1)作用域:

  只在声明所在的块级作用域内有效

{
const PI = 3.1415;
}
console.log(PI);

报错:

  Uncaught ReferenceError: PI is not defined

正确的使用位置

{
const PI = 3.1415;
console.log(PI);
}

输出:

  3.1415

(2)声明之后值就不能改变

const PI = 3.1415;
PI=3;

报错:

  Uncaught TypeError: Assignment to constant variable.

(3)声明后必须立即初始化

const PI;
PI = 3.1415;
console.log(PI);

报错:

  Uncaught SyntaxError: Missing initializer in const declaration

(4)不允许在相同作用域内重复声明同一个变量的

const PI = 3.1415;
console.log(PI);
const PI = 3.1415926;
console.log(PI);

报错:

  Uncaught SyntaxError: Identifier 'PI' has already been declared

正确的用法

const PI = 3.1415;
var s= 3*3*PI;
console.log(s);

输出:

  28.273500000000002

4.常见的面试题

var msg = ["This", "is", "a", "test"];
for (var i = 0; i < msg.length; i++) {
console.log("outer:"+i);
setTimeout(function() {
console.log("index:" + i + ",msg:" + msg[i]);
}, 0);
}

输出: 

outer:0
outer:1
outer:2
outer:3
index:4,msg:undefined
index:4,msg:undefined
index:4,msg:undefined
index:4,msg:undefined

原因:

  setTimeout的执行方式是异步执行

  JavaScript 是单线程的,遇到setTimeout后会另开一条线程

  执行setTimeout里的代码时,同步代码for循环已经执行完成

  整个循环中只有一个iifor循环以及三个回调函数共用,循环结束后i=4,已经超出了原本数组的范围

把var 改成let

var msg = ["This", "is", "a", "test"];
for (let i = 0; i < msg.length; i++) {
console.log("outer:"+i);
setTimeout(function() {
console.log("index:" + i + ",msg:" + msg[i]);
}, 0);
}

输出:

  outer:0

  outer:1

  outer:2
  outer:3
  index:0,msg:This
  index:1,msg:is
  index:2,msg:a
  index:3,msg:test

原因:

  let所声明的变量,只在let命令所在的代码块内有效,而且有暂时性死区的约束

暂时性死区:只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域, 不再受外部的影响

javascript中var、let、const的区别的更多相关文章

  1. javascript中var let const三种变量声明方式

    javascript中var let const三种变量声明方式 1.var  ①var表示声明了一个变量,并且可以同时初始化该变量. ②使用var语句声明的变量的作用域是当前执行位置的上下文:一个函 ...

  2. ES6中var/let/const的区别

    let的含义及let与var的区别: let 声明的变量只在它所在的代码块有效: 如下: for (let i = 0; i < 10; i++) { console.log(i); } con ...

  3. 【前端面试】(四)JavaScript var let const的区别

    视频链接: JavaScript var let const的区别 - Web前端工程师面试题讲解 参考链接: JavaScript 变量 JavaScript Let JavaScript Cons ...

  4. JavaScript中var和this定义变量的区别

    JavaScript中var和this定义变量的区别 在js中声明变量时可以使用var和this,但使用this的有很大一部分参考书是没有的,经过查阅相关资料总结如下: 用var和this声明变量,存 ...

  5. JavaScript中:表达式和语句的区别

    JavaScript中:表达式和语句的区别 Javascript语言精粹:表达式是由运算符构成,并运算产生结果的语法结构.程序是由语句构成,语句则是由“:(分号)”分隔的句子或命令.如果在表达式后面加 ...

  6. var let const 的区别

    Var let const 的区别 1.Var 定义的变量存在变量提升,而了let和const不存在变量提升.即在定义的变量代码上使用该变量,var的会输出undefined,而let的会报错. 2. ...

  7. 浅谈JS中 var let const 变量声明

    浅谈JS中 var let const 变量声明 用var来声明变量会出现的问题: 1. 允许重复的变量声明:导致数据被覆盖 2. 变量提升:怪异的数据访问.闭包问题 3. 全局变量挂载到全局对象:全 ...

  8. JavaScript中var、let和const的区别(转载)

    一.前言 在ES6(ES2015)出现之前,JavaScript中声明变量就只有通过 var 关键字,函数声明是通过 function 关键字,而在ES6之后,声明的方式有 var . let . c ...

  9. javascript中var、let和const的区别

    在javascript中,var.let和const都可以用来声明变量,那么三者有什么区别呢?要回答这个问题,我们可以从先想想:三种不同的声明会影响变量的哪些方面?这些方面也就是变量的特性,那么变量有 ...

随机推荐

  1. 第3章 常用linux命令 3.5 文件压缩命令

    实验六 文件及目录的压缩解压缩相关命令的使用 [实验目的] 1.掌握linux压缩文件实质 2.掌握linux中压缩及解压缩指令的用法 [实验环境] 1. 标准配置PC一台 2. linux操作系统: ...

  2. hive创建表

    一.为什么要创建分区表 1.select查询中会扫描整个表内容,会消耗大量时间.由于相当多的时候人们只关心表中的一部分数据, 故建表时引入了分区概念. 2.hive分区表:是指在创建表时指定的part ...

  3. Linux 防火墙 | Linux 服务器如何开放端口 配置防火墙

    sudo ufw status(如果你是root,则去掉sudo,ufw status)可检查防火墙的状态,我的返回的是:inactive(默认为不活动).sudo ufw version防火墙版本: ...

  4. Docker部署ngnix静态网站

    Hello World 首先获取ngnix镜像(默认的是最新版. docker pull nginx 先来编写一个最简单的Dockerfile,一个Dockerfile修改该Nginx镜像的首页 Do ...

  5. Codeforces Round #558 (Div. 2)-Cat Party (Hard Edition)-(前缀和 + 模拟)

    http://codeforces.com/problemset/problem/1163/B2 题意:有n天,每天有一个颜色,截取前x天,随便抽掉一天,使剩下的各个颜色出现的次数相等. 解题,也可以 ...

  6. LeetCode 301. Remove Invalid Parentheses

    原题链接在这里:https://leetcode.com/problems/remove-invalid-parentheses/ 题目: Remove the minimum number of i ...

  7. C++智能指针总结

    本文介绍c++里面的四个智能指针: auto_ptr, shared_ptr, weak_ptr, unique_ptr 其中后三个是c++11支持,并且第一个已经被c++11弃用. 为什么要使用智能 ...

  8. NodeJS代码组织与部署

    使用NodeJS编写程序前,为了有个良好的开端,首先需要准备好代码的目录结构和部署方式,就如同修房子要先搭脚手架.本章将介绍与之相关的各种知识. 一.模块路径解析规则 我们已经知道,require函数 ...

  9. December Challenge 2019 Division 1 题解

    传送门 当我打开比赛界面的时候所有题目都已经被一血了-- BINXOR 直接把异或之后二进制最多和最少能有多少个\(1\)算出来,在这个范围内枚举,组合数算一下就行了.注意\(1\)的个数是\(2\) ...

  10. [2019BUAA软件工程]个人期末总结感想

    写在前面   经过一学期对于软件工程的学习,笔者完成了一次结对编程以及三个周期的敏捷开发流程.在本博客中笔者对于一学期的学习进行了总结,并对于自己最初的疑惑做出了回答.   笔者在学期开始前应课程要求 ...