首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JS中var与let、const的区别

    var与let、const 一、var声明的变量会挂载在window上,而let和const声明的变量不会: var a = 100; console.log(a,window.a); // 100...这个变量 let b = 10; console.log(c); // 报错:c is not defined ===> 找不到c这个变量 const c = 10; 三、let和const声明形成块作用域.../ 报错:c is not defined ===> 找不到c这个变量 四、同一作用域下let和const不能声明同名变量,而var可以 var a = 100; console.log(a); //...五、暂存死区 var a = 100; if(1){ a = 10; //在当前块作用域中存在a使用let/const声明的情况下,给a赋值10时,只会在当前作用域找变量a, // 而这时...* *   2、声明后不能再修改 * *   3、如果声明的是复合类型数据,可以修改其属性 * * */ const a = 100; const list = []; list[0] = 10;

    2.3K20

    JS中var、const、let区别

    var特点 a. 没有块级作用域,仅有全局作用域、函数作用域 b. 可以重复声明 c. 有变量提升 d. 声明的时候可以不赋值,且值可以修改 let特点 a....没有全局作用域,有块级作用域、函数作用域 b. 有暂时性死区,不可重复声明 c. 没有变量提升 d. 声明的时候可以不赋值,且值可以修改 const特点 a....没有全局作用域,有块级作用域、函数作用域 b. 有暂时性死区,不可重复声明 c. 没有变量提升 d....声明的时候必须赋值,且值如果是简单数据类型的话,不可以修改 其他: 声明变量的时候,如果不采用关键字的话,默认为全局变量 面试真题: var btns = document.getElementsByTagName...('button') for (var i = 0; i < btns.length; i++) { btns[i].onclick = function () { console.log

    1.3K30

    Js中var let const 区别

    二、var 如果使用关键字 var 声明变量,那么这个变量就属于当前的函数作用域,如果声明是发生在任何函数外的顶层声明,那么这个变量就属于全局作用域。...举例说明: var a = 1; //此处声明的变量a为全局变量 function foo(){ var a = 2;//此处声明的变量a为函数foo的局部变量 console.log(a)...三、变量声明提升 提升是指无论 var 出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在作用域中到处都可以访问到。注意只有变量声明才会提升,对变量赋值并不会提升。...声明的变量,具有如下几个特点: let 声明的变量具有块作用域的特征。...六、总结 var 声明的变量属于函数作用域,let 和 const 声明的变量属于块级作用域; var 存在变量提升现象,而 let 和 const 没有此类现象; var 变量可以重复声明,而在同一个块级作用域

    1.8K30

    js中var、let、const区别

    javascript中有三种声明变量的方式:var、let、const 1.var 作用域:全局或局部 var的作用域可以是全局或是局部,以下分四种情况说明: (1).当var关键字声明于函数内时是局部变量...(2)当var关键字声明于函数外时是全局变量,此时不论在函数外部还是内部都可以访问到。...(3)当var关键字第一次声明变量于函数外时是全局变量,并且在函数内又使用var关键字声明了同一名字的变量,那么后声明这个是局部变量只作用于函数内,对函数外第一次声明的变量不影响。...(4)当var关键字第一次声明变量于函数外时是全局变量,并且在函数内直接访问赋值了,那么此变量即是声明的那个变量。 var定义的变量可以修改,如果不初始化会输出undefined,但不会报错。...2.let 作用域:局部(块级作用域) let是块级作用域,函数内部使用let定义后,对函数外部无影响,在同一块域内let不可重复声明 3.const 作用域:局部(块级作用域) const定义的变量作为一常量

    2.2K20

    JS中var、let和const的区别详解

    一、概述 在ES5中,声明变量只有var关键字,声明函数只有function关键字; 因为var声明的变量,内层变量可能覆盖外层变量的问题以及用来计数的循环变量泄露为全局变量; 在ES6之后,声明的方式有...var 、 let 、 const 、 function 、 class,我们来重点讨论var、let和const的区别; 二、var 1、作用域 说明: 使用var声明一个变量,如果在函数之内,则作用域在当前函数之内...; 无论 var 出现在一个作用域的哪个位置,这个声明都属于当前的整个作用域,在其中到处都可以访问到; 只有变量声明才会提升,对变量赋值并不会提升; console.log(a);//undefined...但这并不意味着它所持有的值是不可变的,只是变量标识符不能重新分配; 五、总结 var 声明的变量属于函数作用域,let 和 const 声明的变量属于块级作用域; var 存在变量提升现象,而 let...和 const 没有此类现象; var 变量可以重复声明,而在同一个块级作用域,let 变量不能重新声明,const 变量不能修改; 六、参考资料 (不分先后顺序,感谢这些文章的作者!)

    21510

    Vue之块级作用域let和var

    1.背景 js的作者Brendan Eich公开说明过var其实是js语言设计上的错误,但是这种错误多半不能修复和移除,所以大概在十几年前,Brendan Eich就修复了这个问题,添加了一个新的关键词...:let let可以看做是更完美的var 2.var 1.var var在声明一个变量时,该变量只有在函数中才有自己的作用,在if和for中没有自己的作用域。...在for中的i是没有自己的作用域的,且js是异步执行,在js执行完后,才开始渲染页面,那就意味着我们在点击已经渲染出的button时,for循环已经遍历到最后一个,且这个for中的i没有自己的作用域,他是被共享的...那这时候,为了实现效果就会引入函数(因为var在函数中有自己的作用域),借助函数的作用域让每个i都有自己的作用域,点击按钮出现相应序号。这就是我们js常用的闭包。...的区别 用let声明的变量在if、for、function内都有自己的作用域 用var声明的变量只有在function内有自己的作用域

    1.2K10

    js中const,var,let定义变量的区别

    js中const,var,let定义变量的区别 1.const定义变量不可以修改,而且必须初始化 const b = 2;//正确 // const b;//错误,必须初始化 console.log...('函数外const定义b:' + b);//有输出值 // b = 5; // console.log('函数外修改const定义b:' + b);//无法输出 2.var定义的变量可以修改...,如果不初始化会输出undefined,不会报错 var a = 1; // var a;//不会报错 console.log('函数外var定义a:' + a);//可以输出a...=1 function change(){ a = 4; console.log('函数内var定义a:' + a);//可以输出a=4 } change...(); console.log('函数调用后var定义a为函数内部修改值:' + a);//可以输出a=4 3.let是块级作用域,函数内部使用let定义后,对函数外部无影响。

    3.3K30

    js中的作用域

    前言 相信自从es6出来之后,你一定多少知道或者已经在项目中实践了部分的块级作用域,在函数或者类的内部命名变量已经在使用let了,但是你知道它真正的作用是什么吗?...es6之前的作用域 特点1 :js只有函数级作用域以及全局两种 特点2 :不通过var声明的变量直接赋值也可以用并且可以访问,原理是直接赋值到了window对象属性变量下,两者如果同时定义,那么会覆盖使用...,函数内可以访问外部作用域,而全局是不可以访问函数作用域内的变量或者方法的 var a=b=c=12 function demo(){ var z=13 console.log(b)//12...,利用let块级作用域特性,区别就是定义变量时 i是块级变量,所以定义的函数中的变量也是当时的块级作用域,不随外面非块级元素值变化影响 var arr=[] for(let i=0;i<10;i++)...,已经变成4 } 变量提升(js-hoisting) 场景一 变量可以先使用后申明,其申明会自动提前 a=12 console.log(a) var a //这句申明会提前 ,在window环境下不会报错是因为赋值在了

    3.2K20

    JS作用域

    JavaScript的作用域有全局作用域和局部作用域 先通过一下代码来体验下作用域 var x = 1; function f1(){ var y = 2; x = 10; console.log...ReferenceError: y is not defined at :7:13 上述代码中变量x就是全局作用域,方法f1的作用域也是全局,f1方法中的变量y是局部的,y的作用范围仅限f1方法体内...,离开了f1的方法体的作用范围,就无法获取到y的值,所以上述的例子中最后打印y的时候是undefined 我们再来看下面的例子 var a = 1; function f1(){ console.log...3,所以f1()方法执行完毕后输出a的值是3,上面这段代码相对大家应该都比较容易 接下来再看看下面的例子 var a = 1; function f1(){ console.log(a);...就能猜到他的结果输出了 接下来用一道面试题来举个例子 var a = 10; function f1(){ var b = 2*a; var a = 20; var c = a+

    11510

    JavaScript(JS)中var和let的区别及推荐

    从以下几个方面解释: 作用域:var是函数作用域,而let是块作用域,也就是说,在函数内声明了var,整个函数内都是有效的,比如说在for循环内定义了一个var变量,实际上其在for循环以外也是可以访问的...,而let由于是块作用域,所以如果在块作用域内(比如说for循环内)定义的变量,在其外面是不可被访问的,所以let用在for (let i; i 的写法 let不能在定义之前访问该变量...也就是说,let必须是先定义,再使用,而var先使用后声明也行,只不过直接使用但是没有却没有定义的时候,其值为undefined,实际上var有一个变量提升的过程。...也就是说,当这个函数的作用域被创建的时候,实际上var定义的变量都会被创建,并且如果此时没有初始化的话,则默认会初始化一个undefined, 补充: var js=function(){} 这种叫做函数表达式...必须先定义后使用 function js(){}这种是函数声明 可以先使用后定义 它会对函数的声明进行一个提升,提升只是相当于提前声明,函数提前声明,在使用的时候不会报错。

    1.4K50
    领券