变量:
var function es6提供的let const class import定义变量的关键字
备注:不能忽略函数的形参 函数的私有变量
Var 定义变量 变量提升但是不能定义 给window添加一个对应的属性
Function 既可以提前声明 同时还定义了
定义:所谓的定义就是给变量赋值
Let 是es6提供的一种声明变量的方式
1.没有变量提升的功能,在声明之前不能使用(不能提前声明)
2.不能重复声明
3.不会给window添加属性
作用域
Var的作用域
Var声明的变量 作用域分两种
全局作用域
在window 下声明的变量或者在函数外声明的变量,
局部作用域
在函数内部声明的变量
了解浏览器执行的机制
浏览器在执行的时候,首先开辟一大空间叫window下面主要分两个模块,一个叫 栈,一个叫堆。栈用来存放变量的内存地址,堆主要存放代码块。然后浏览器从上 到下执行代码。
Function申请的变量
Function声明的变量也会给window添加一个属性 属性值是方法。
函数归属问题? 函数归谁,跟他在哪调用无关,跟他在哪定义有关
任何一个函数执行后都有一个返回值,如果写了return 就返回return的值
块级作用域
带{}的都是块级作用域,if(){} for(){} 对象{}
Var 没有块级作用域这个概念, let和const有块级作用域这个概念
- 在块级作用域下var 和 function 跟在window下一样,function有个特殊的,在块级作用域前只会提前声明不会定义。
-
在块级作用域下 let 和 const 声明的变量是私有的
- For循环下let声明的变量不会泄露,因为事件是异步的,for循环结束后i是3并且还是全局的,点击了li最后alert出i,i 此时是n,所以都会弹出n
块级作用域和对象的区分
{}如果想不傲世对象,不能放在首行,就在{}前面不能没有任何东西,如果有了就是对象。没有就代表块级作用域
暂时性死区
如果块级作用域内使用let和const命令声明变量了,这个区域就会被这个变量强制绑定,凡是在声明之前这些变量都是不可用的,使用会报错,这就是暂时性死区
使用便利b在定义变量b之前了,出现了暂时性死区
Let a = a; 报错,赋值运算是从右往左,右边使用变量a结果发现a没有声明,而let语法规定不能在没定义前使用变量,所以报错。
Var a = a; 不报错,UI那我var可以变量提升,在等号赋值的时候,是从右往左, 使用变量a,此时a是undefined,赋值时就是把undefined赋值给a,所有a还是undefined
函数参数默认值
- 写法上 有默认值得写后面,没有默认值写前面
- 如果传对应的参数,就不要默认值,不是先赋默认值,然后用是参数覆盖