【JS学习】var let const声明变量的异同点

前言:

本博客系列为学习后盾人js教程过程中的记录与产出,如果对你有帮助,欢迎关注,点赞,分享。不足之处也欢迎指正,作者会积极思考与改正。

总述

js中有三种声明变量的方法:var,let,const。他们各自有各自的有特点。

声明格式 声明 变量提升 作用域 是否存在于windows对象中
var a="abc"; 变量 全局或者函数内部
let b="abc"; 变量 块区域以及向下兼容或者函数内部
const c="anc"; 常量(但引用类型依然可可变) 块区域以及向下兼容或者函数内部

案列

实践出真知

  1. 变量提升

    所谓变量提升是指:在执行js代码时,编译器会预先将声明变量的语句执行(与let,const的区别)

    //案列一:
    
        a="123";//此处不会报错,因为编译器会先执行var a语句,再执行此句
    var a;
    console.log(a);//123 b="123";//此处会报错,因为初始化前无法访问“b”
    let b;
    console.log(b);//123 c="123";
    const c;//此处会报错,因为常量声明中缺少初始值设定项
    console.log(c);//123 //案例二:if(false)里面的var语句也会执行
    var a = "1";
    function hd() {//此处会先执行if内部的var a
    if (false) {
    var a = "0";
    }
    console.log(a);//输出undefine
    }
    hd(); let a = "1";//向下兼容的块作用域
    function hd() {//不会先执行if内部的let a
    if (false) {
    let a = "0";
    }
    console.log(a);//输出1
    }
    hd(); const a = "1";
    function hd() {//不会先执行if内部的const a
    if (false) {
    const a = "0";
    }
    console.log(a);//输出1
    }
    hd();
  2. 作用域:var存在于最近函数或者全局作用域中(没有块作用域)

    //案列一:正常语句中(与let,const的区别)
    var i=-1;
    for(var i=0;i<4;i++){ }
    console.log(i);//此处会打印4 因为var定义的变量具有全局作用域 let i=-1;
    for(let i=0;i<4;i++){//此处的let只会作用在{}块域内 }
    console.log(i);//此处会打印-1 因为let定义的变量具有块作用域 const a=-1;
    for(let i=0;i<4;i++){
    const a=1;//此处的const只会作用在{}块域内 }
    console.log(a);//此处会打印-1 //案列二:函数内部(let,const都是这样)
    var a=1;
    function test(){
    var a=2;
    console.log(a);//函数内部打印2;在方法内部全局作用 }
    test();
    console.log(a);//依然打印1 函数内部不影响外部 let a=1;
    function test(){
    let a=2;
    console.log(a);//函数内部打印2;在方法内部全局作用 }
    test();
    console.log(a);//依然打印1 函数内部不影响外部 const a=1;
    function test(){
    const a=2;
    console.log(a);//函数内部打印2;在方法内部全局作用 }
    test();
    console.log(a);//依然打印1 函数内部不影响外部
  3. var的全局变量会存储在windows对象中(与let,const的区别)

    		var a=1;
    console.log(window.a);//输出1 let a=1;
    console.log(window.a);//输出undefined const a=1;
    console.log(window.a);//输出undefined
  4. const定义常量 但注意当为引用类型时依然可以改变

    	const a=1;
    a=2;//报错,不可重复赋值 const a=[1,2,3];
    a[1]=1;
    console.log(a);//输出[1,2,3],可用freeze方法冻结

尾记

有任何问题,欢迎私聊哟~~~

也可关注公众号“诗与凉风”联系作者哦~~

【JS学习】var let const声明变量的异同点的更多相关文章

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

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

  2. var、let、const声明变量的区别

    let和var声明变量的区别:1.let所声明的变量只在let命令所在的代码块内有效.(块级作用域) for(let i=0;i<10;i++){ // ... } console.log(i) ...

  3. let、var、const声明的区别

    前言 看了方应杭老师的一篇解释let的文章,对JavaScript中的声明有了深刻的理解,这里也就有了总结一下JavaScript中各种声明之间区别的这篇文章. JavaScript中变量声明机制 首 ...

  4. 深度理解js中var let const 区别

    首先要理解js中作用域的概念 作用域:指的是一个变量的作用范围 1.全局作用域 直接写在script中的js代码,在js中,万物皆对象,都在全局作用域,全局作用域在页面打开时创建,在全局作用域中有一个 ...

  5. ES6 let const 声明变量 块级作用域

    ES6 中除了使用 var 定义变量,还有let.const,定义变量. function getValue(condition){ console.log(typeof value2); // un ...

  6. JS学习笔记(二)变量、作用域及内存问题

    一.基本类型和引用类型的值 变量可能包含两种不同数据类型的值:基本类型值和引用类型值. 基本类型值:简单的数据段. 引用类型值:可能由多个值构成的对象. 当将一个值赋给变量时,解析器必须确定这个值是基 ...

  7. HttpRunner学习5--使用variables声明变量

    前言 在HttpRunner中,如果需要声明变量,可以通过关键字 variables 来完成,要引用声明的变量,则是通过 $+变量名 (如 $token )来实现.variables 可以在 conf ...

  8. Javascript 基础学习(三)js 的原始类型和声明变量

    java的基本数据类型一共有 byte short int long float double char boolean js中定义变量使用关键字 var js的原始类型(五个) String: 字符 ...

  9. js中使用const声明变量时需要注意

    const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址(初始化的内容)不得改动.对于简单类型的数据(数值.字符串.布尔值),值就保存在变量指向的那个内存地址,因此等同于常量. 简单 ...

随机推荐

  1. STL—— 容器(vector)的数据插入之 insert()

    vector 容器可以使用 vectorName.insert() 方法插入元素,vectorName.insert() 函数一共有4种重载方法: 第一种 insert() 用法:在指定地址插入单个元 ...

  2. C++ 虚函数表与多态 —— 多重继承的虚函数表 & 内存布局

    多重继承的虚函数表会有两个虚表指针,分别指向两个虚函数表,如下代码中的 vptr_s_1.vptr_s_2,Son类继承自 Father 和 Mather 类,并且改写了 Father::func_1 ...

  3. eclipse提示JVM版本太低

    解决方案:去eclipse的安装路径找到eclipse.ini文件,然后在头部指定JVM的版本(第一第二行) -vm C:/Program Files/Java/jdk-11.0.9/bin -sta ...

  4. Asp.net core验证类ModelStateDictionary的bug

    在使用.net core 3.1 时发现明明没有验证请求类属性,甚至已经加了默认值 但是验证类时依然会报错 经过网上百度等搜索,尝试使用可空类型赋值默认值 果然验证类没有报错 不清楚是微软的bug还是 ...

  5. 双向数据绑定 v-model

    双向数据绑定 就是既可以从页面传到数据也可以从数据到页面 初始运行结果为: 在输入框 更改数据 相应的输入框上的也会相对改变 然后再试试利用控制台更改数据 可以看到数据也被改变了 而且输入框中的内容也 ...

  6. create-react-app 基于ts项目,使用react-router-dom搭建项目

    准备工作 来个react项目 create-react-app 基于TS的项目 ts项目安装后 删除node_modules,重新 yarn install, 不然jsx会报错 安装React-rou ...

  7. 第九章 Nacos Config--服务配置

    今天咱们接着 上一篇 第八章 SMS–短信服务 继续写 SpringCloud Alibaba全家桶 -> 第九章 Nacos Config–服务配置,废话不多说,开干 9.1 服务配置中心介绍 ...

  8. python爬虫爬取安居客并进行简单数据分析

    本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,如有问题请及时联系我们以作处理 爬取过程一.指定爬取数据二.设置请求头防止反爬三.分析页面并且与网页源码进行比对四.分析页面整理数据 ...

  9. 每天学一点ES6(一)开始

    最近学习vue,发现很多用法都不会了,虽然照猫画虎可以跑起来,但是总感觉很朦胧,是是而非的感觉不太好. 听说这些都是ES6的用法,所以决定要学习一下ES6 ES6 全称:ECMASctipt 6 简称 ...

  10. C#中打印拼接的字符串

    实例化打印文档 //声明打印对象 PrintDocument pd = new PrintDocument(); int ilvPreviewIndex = 0; 在打印事件中设置基本属性 priva ...