以前的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相关推荐

  1. ES6新特性_let变量声明以及声明特性---JavaScript_ECMAScript_ES6-ES11新特性工作笔记003

    技术交流QQ群[JAVA,C++,Python,.NET,BigData,AI]:170933152 首先看es6的第一个变量声明特性,以前咱们用 var 声明,现在可以用let来声明变量. 可以看到 ...

  2. ES6的变量声明详述

    目录 1.var声明变量的问题 2.使用let声明变量 3.使用const声明变量 1.var声明变量的问题 (1)允许重复的变量声明:导致数据被覆盖 var a = 1; function prin ...

  3. ES5和ES6中的变量声明提升

    ES5和ES6中的变量声明提升 Example1: a=2; var a; console.log( a ); //结果为2 Example2: console.log( a ); //结果是unde ...

  4. ES6/06/ES6简介,ES6新增语法,let声明变量,const声明常量,var,let和const总结,数组解构,对象解构,箭头函数,剩余参数

    ES6简介 ES全称:ECMAScript ; 由ECMA国际化组织制定的标准脚本语言的标准化规范: 为什么使用ES6? 每一次标准的诞生都意味着语言的完善,功能的加强,JavaScript语言本身也 ...

  5. 石川es6课程---3、变量let和常量const

    石川es6课程---3.变量let和常量const 一.总结 一句话总结: let非常好用,尤其是let的块级作用域可以解决之前要(function(){})()立刻执行函数做的块级作用域 1.js中 ...

  6. php变量 声明提升,TypeScript:let和const变量声明

    在开始介绍let和const变量声明前,有必要先了解下JavaScript里的var变量声明. var变量声明 全局声明 var声明在函数体外,所声明的变量为全局变量.var name = " ...

  7. 必须声明标量变量 @sum_level。_ES6系列—新的变量声明方式

    在ES5中,变量声明只有var和function以及隐式声明三种,在ES6中则增加了let.const.import和class四种. 1. let 1.1 块级作用域 let声明的变量的作用域是块级 ...

  8. TypeScript 变量声明

    TypeScript 变量声明 本节介绍 var let const 这三种变量的声明方式,重点讨论作用域与变量提升的相关知识点,这部分往往也是面试常考部分,需要多加注意. 1. 慕课解释 TypeS ...

  9. 可以声明一个抽象类类型变量_TypeScript系列(二)变量声明和数据类型

    一,变量声明 TypeScript是JavaScript的超集,在变量声明方式方面,关键字是和JavaScript保持一致的,并且推荐较新的 let 和 const 代替 var .至于为什么这样做, ...

  10. 系统学习 TypeScript(四)——变量声明的初步学习

    前言 认识了 TypeScript 中的基础类型,接下来当然是变量声明的相关学习了. 声明多维数组 假如有这么一个声明: let arr3: number[][][]; 想要知道 arr3 的具体类型 ...

最新文章

  1. RESTful风格及其SpringMVC实现
  2. 年终收藏!吴恩达盘点2020年度AI热门事件
  3. PlanAhead与ChipScope
  4. 使用免费虚拟服务器建站并实现域名解析
  5. IIS 的负载均衡【IIS7.0以上才可以使用】---- Application Request Routing(ARR)
  6. Mac系统修改root用户密码,mac切换root用户登录实例演示
  7. Julia语言:让高性能科学计算人人可用
  8. jdk9与jdk11哪个好_JDK 9、10和11中的安全性增强
  9. C语言-字符串处理函数strcat
  10. c语言表达式10 3的结果是,C语言程序设计--第3讲运算符与表达式.ppt
  11. z-blog php 静态设置,Nginx的Z-Blog的伪静态配置方法
  12. 将txt文档按行分割
  13. 获取对话框当前cfont_flutter根据控件位置弹出对话框
  14. Hyperworks——Optistruct学习分享
  15. IDEA离线安装maven helper插件
  16. 美团2017校园招聘编程题
  17. vue中printJS打印表格---json
  18. ds18b20驱动程序Linux,基于linux下的ds18b20驱动程序的编写
  19. 如何在手机APP中通过H5方式集成监控摄像头实时直播画面
  20. 华视100UC 身份证阅读器 Java

热门文章

  1. 萨维奇(Savitch)定理证明
  2. 学院后勤报修系统php_企业智能故障报修系统,助你轻松解决设备维修难题
  3. python实现卷积操作
  4. Linux-eval命令
  5. android系统安全测试,Android 安全测试初探 (二)
  6. Android tftp服务器,Ubuntu下配置TFTP服务以及 android下使用TFTP
  7. PyTorch载入图片ToTensor,PIL和OpenCV读取图片plt.imread和PIL.Image.open
  8. python找到二维数据矩阵中的最大最小值直接使用min、max函数
  9. php ckfinder basedir,ckfinder后,上传文件
  10. python mssql get image bin_python 使用pymssql连接sql server数据库