深入javaScript变量声明
来源:互联网 发布:网络爬虫 维基百科 编辑:程序博客网 时间:2024/06/12 01:22
javaScript的变量声明在ES6之前我们都知道是var a= b; 这简简单单的一句话其实js在内部出了以很多东西。在ES6新增了let const语句之后,有让变量的声明多了方式。这里我们就深入一些javaScript的变量声明;
我们定义一个var a = 1;这一句话其实这里javaScript在后台可以归纳为完成了三步操作;①创建变量a;在内存中开辟一块区域来存放a;这一步我们用的是var 是有声明提升的。关于let 和 const官方文档说的是没有声明提升的。但是我们深入发掘就会觉得很奇怪,我们后面在讲。②变量a的初始化,初始化为undefined,这一步实在声明变量之后紧跟着完成的;③变量a的赋值,这一步我们程序执行到var a =1;这条语句的时候执行的,是词法作用域决定的。这里短短的一句话javaScript就在内部执行了这么多。
上面是声明一个没有的变量的情况,如果是声明一个已有的变量那么,javaScript将不会再内存中在开辟区域,也不会初始化。如果是单纯的声明并没有赋值那么变量其实没有任何变化,如果是生命加赋值那么变量的值将发生变化。
var a =1;console.log(a);//1var a;console.log(a);//1var a =2;console.log(a);//2
下来我们说说ES6的let 和 const。let 和 const声明的都是局部变量,const的声明的是常量。let 和 const的出现让javaScript变量的声明更加的严谨和严格。let 和 const对声明的变量十分的挑剔,首先必须在同一个块级作用域中必须是第一次声明,如果之前声明过就会报错,而且声明之后在同一个块级作用域中就不能再次声明,不然也会报错。不同块级作用域中的变量相互是不影响的。这解决了以前for循环输入1-10 但每次都是10的问题。因为每次在for循环的循环体内部都声明了一个let 变量。所以值是不同的。这些知识es入门都有详情解答。
我们这里来看一下let和const和var声明在javaScript内部有什么区别;
其实在ES6很早之前的官方文档其实写的let和const的是存在声明提升的的,但是后来改了。我们看出他们内部一定经过了激烈的讨论我们来看一下代码;
var c=1;{ console.log(c) //Uncaught ReferenceError: c is not defined let c = 2;}这种现象官方文档叫做“暂时性死区”。在一个块级作用域内我们必须在使用let创建一个对象之后才能使用。从作用域开始到声明之前这块区域就叫做“暂时性死区”。其实这里c在块级作用域内的let c是声明提升了得,不然我们应该访问到的是外层的c变量。但是虽然创建提升了,但是没有初始化。我们知道在一个var a = 1;之前访问a,返回的是undefined。但是let 和 const 并没有初始化为undefined的这一步,只有执行到let c =2 这一步才初始化c的值。所以在“{"到let c=2这块区域内c是没有任何值得。也就是”暂时性死区“所以我们看到let和const其实是有”声明提升“的。
所以let 和const声明一个变量只用2步:①创建变量(在作用于内提升)②初始化(在执行到声明的地方);
我们在书写javaScript时应该尽量用到let和const 。别看这一点改变,这会让我们代码更健壮,也会避免不必要的错误。
- 深入javaScript变量声明
- JavaScript变量声明相关
- Javascript变量声明技巧
- JavaScript变量声明
- JavaScript 变量声明
- javascript变量声明提升
- 重新声明 JavaScript 变量
- javascript变量之声明
- javascript变量声明提升
- javascript变量声明
- JavaScript变量的声明
- JavaScript变量声明提升
- javascript变量声明
- JavaScript 变量声明提升
- javascript变量声明提升
- JavaScript 变量声明提前
- javascript变量声明提升
- 谈javascript变量声明
- 2---LeetCode【Reverse Integer】|C语言|总结
- TCP报文段首部格式详解
- JavaScript代码规范
- poll机制之内核实现简要分析
- 原码、反码、补码、移码扫盲
- 深入javaScript变量声明
- Linux学习44_linux下rm和rmdir的区别和使用
- 文章标题
- HDU 4756 树形DP + prim
- Python3安装tkinter
- ssh is not mapped [FROM ssh]
- Python基础语法之——Lambda
- hibernate的工作原理以及为什么使用
- jpa、mybatis事务混合测试记录