ES6深入浅出-1 新版变量声明:let 和 const-2.视频 let和const
以前的var方式声明不好用
a=1回声明一个全局变量,
输出了1 说明a=1确实声明了一个全局变量。
但是你把放在其他的地方,就不是声明全局变量了。
如果外面有个全局变量a 那么函数里面就是给a赋值
有两层函数的时候,直接使用的是局部变量a,也就是fn函数里面的a
如果当前没有a就声明一个全局变量a。如果有a就利用这个a。下面当前就是有a的
这样用的就是最外面的var a
如果外面也没有,这时候才会去声明一个全局变量
所以a=1会声明一个全局变量是错的,只有在没有a这个变量的情况下才会隐式的去声明一个全局变量
所以a=1就是含义不明
不建议使用
这样打印出来一个a是对的
没有声明的情况下输出a页面会报错。没有a任何的定义就去使用它
没有报错
不执行的代码影响了,执行的代码
var a会自动提升到上面去,虽然它不会执行,它会给代码一些不符合逻辑的地方,var a 会乱提升
第二个问题
不使用全局变量,全局变量会经常有问题,比如声明了一个全局变量,别人用了我不知道。
用一个函数包起来。 这样var a就是一个局部变量。
函数给他一个名字,不管叫啥名,都是全局变量。 当前x是全局变量,frank是全局变量
把var a放在函数里面 那么a就是一个局部变量。
把a包含在函数x里面。那么函数x就是一个全部变量了。
匿名函数直接调用,在函数的最后面加个括号。但是语法错误。
避免这个语法错误。那么总的都包含在一个括号里面
声明一个函数,然后马上调用它,就是只是为了这个函数没有名字而已。然后包含在括号里面,是为了不让它报语法错误。搞这么多事情就是为了不暴露全局变量
let的特点,不会往外跑,只要看到了花括号就不会再网上升了。let就是你写在哪就是哪 不会乱跑。
如果这时候在打印a 就会报错,提示未定义。
把a隐藏起来不作为全局变量,在Es6之前 ,js必须使用一个立即执行函数的变态方案,新人完全看不懂
let就是为了方便的使用局部变量,而不需要引用一个函数。
let的作用域只管到花括号
用var 就不会报错。
let的第二个特点 也是可以嵌套的
这个语法叫做块,把一堆代码扩起来。
在一个新的块里面,还没生命a 就用a
既不会用外面的a 也不会用里面的a。直接就报错了。这是一个很好的习惯,这样就不会出现一些奇异的代码
let的第二个特点,如果你在一个block里面。没有用let生命变量就是用这边量。直接就会报错。
这个特点叫做Temp Dead Zone 临时死区
下面选中的这部分就是临时死区,在这里面,a是不能使用的,一旦使用就报语法错误。
换句话说就是不生命就调用, 就会直接报错
const
a的作用域只在选中那个括号里面。
const只有一次赋值机会,后面再赋值就报错
再次let a 也会报错,一个变量不能声明两次,这里直接报错。
js终于知道在写代码的时候 就告诉你 这里有错。
const的情况。const是常量的意思。只能赋值一次
总结
定义const a不赋值,没运行直接就报错
转载于:https://www.cnblogs.com/wangjunwei/p/11546457.html
ES6深入浅出-1 新版变量声明:let 和 const-2.视频 let和const相关推荐
- ES6新特性_let变量声明以及声明特性---JavaScript_ECMAScript_ES6-ES11新特性工作笔记003
技术交流QQ群[JAVA,C++,Python,.NET,BigData,AI]:170933152 首先看es6的第一个变量声明特性,以前咱们用 var 声明,现在可以用let来声明变量. 可以看到 ...
- ES6的变量声明详述
目录 1.var声明变量的问题 2.使用let声明变量 3.使用const声明变量 1.var声明变量的问题 (1)允许重复的变量声明:导致数据被覆盖 var a = 1; function prin ...
- ES5和ES6中的变量声明提升
ES5和ES6中的变量声明提升 Example1: a=2; var a; console.log( a ); //结果为2 Example2: console.log( a ); //结果是unde ...
- ES6/06/ES6简介,ES6新增语法,let声明变量,const声明常量,var,let和const总结,数组解构,对象解构,箭头函数,剩余参数
ES6简介 ES全称:ECMAScript ; 由ECMA国际化组织制定的标准脚本语言的标准化规范: 为什么使用ES6? 每一次标准的诞生都意味着语言的完善,功能的加强,JavaScript语言本身也 ...
- 石川es6课程---3、变量let和常量const
石川es6课程---3.变量let和常量const 一.总结 一句话总结: let非常好用,尤其是let的块级作用域可以解决之前要(function(){})()立刻执行函数做的块级作用域 1.js中 ...
- php变量 声明提升,TypeScript:let和const变量声明
在开始介绍let和const变量声明前,有必要先了解下JavaScript里的var变量声明. var变量声明 全局声明 var声明在函数体外,所声明的变量为全局变量.var name = " ...
- 必须声明标量变量 @sum_level。_ES6系列—新的变量声明方式
在ES5中,变量声明只有var和function以及隐式声明三种,在ES6中则增加了let.const.import和class四种. 1. let 1.1 块级作用域 let声明的变量的作用域是块级 ...
- TypeScript 变量声明
TypeScript 变量声明 本节介绍 var let const 这三种变量的声明方式,重点讨论作用域与变量提升的相关知识点,这部分往往也是面试常考部分,需要多加注意. 1. 慕课解释 TypeS ...
- 可以声明一个抽象类类型变量_TypeScript系列(二)变量声明和数据类型
一,变量声明 TypeScript是JavaScript的超集,在变量声明方式方面,关键字是和JavaScript保持一致的,并且推荐较新的 let 和 const 代替 var .至于为什么这样做, ...
- 系统学习 TypeScript(四)——变量声明的初步学习
前言 认识了 TypeScript 中的基础类型,接下来当然是变量声明的相关学习了. 声明多维数组 假如有这么一个声明: let arr3: number[][][]; 想要知道 arr3 的具体类型 ...
最新文章
- RESTful风格及其SpringMVC实现
- 年终收藏!吴恩达盘点2020年度AI热门事件
- PlanAhead与ChipScope
- 使用免费虚拟服务器建站并实现域名解析
- IIS 的负载均衡【IIS7.0以上才可以使用】---- Application Request Routing(ARR)
- Mac系统修改root用户密码,mac切换root用户登录实例演示
- Julia语言:让高性能科学计算人人可用
- jdk9与jdk11哪个好_JDK 9、10和11中的安全性增强
- C语言-字符串处理函数strcat
- c语言表达式10 3的结果是,C语言程序设计--第3讲运算符与表达式.ppt
- z-blog php 静态设置,Nginx的Z-Blog的伪静态配置方法
- 将txt文档按行分割
- 获取对话框当前cfont_flutter根据控件位置弹出对话框
- Hyperworks——Optistruct学习分享
- IDEA离线安装maven helper插件
- 美团2017校园招聘编程题
- vue中printJS打印表格---json
- ds18b20驱动程序Linux,基于linux下的ds18b20驱动程序的编写
- 如何在手机APP中通过H5方式集成监控摄像头实时直播画面
- 华视100UC 身份证阅读器 Java
热门文章
- 萨维奇(Savitch)定理证明
- 学院后勤报修系统php_企业智能故障报修系统,助你轻松解决设备维修难题
- python实现卷积操作
- Linux-eval命令
- android系统安全测试,Android 安全测试初探 (二)
- Android tftp服务器,Ubuntu下配置TFTP服务以及 android下使用TFTP
- PyTorch载入图片ToTensor,PIL和OpenCV读取图片plt.imread和PIL.Image.open
- python找到二维数据矩阵中的最大最小值直接使用min、max函数
- php ckfinder basedir,ckfinder后,上传文件
- python mssql get image bin_python 使用pymssql连接sql server数据库