严格模式
- js有两中开发模式:
非严格模式(默认)+严格模式(“ues strict”)
- 严格模式:会进行更严格的代码检查
- 区别:
以前可以的特性在严格模式下可能被禁止使用
以前可以使用的代码方式,在严格模式下会直接报错
- 开启严格模式:
- 字符串命令“ues strict”
- 位置:当前作用域的最顶端
- 兼容性问题:
- 严格模式不存在兼容的问题,如果当前的浏览器支持严格模式,那么扫描到命令的时候会开启严格模式检查,如果不支持则直接忽略。
- 使用建议:写代码的时候全部开启严格模式
- 在严格模式下的使用注意点:
- 1.所用的变量必须使用var声明(否则会报错)
- 2.禁止使用八进制()
var num = 033 //数值以0开头,是以八进制的方式来处理
直接报错
var num = 0x33 //数值以0x开头,是以十六进制的方式来处理
不会报错
在严格模式下,不能删除全局变量(直接报错)
在默认情况下,可以删除全局变量,会静默失败(报错却不显示)
- 5.不能在if语句中声明函数
- 6.函数的形参不能出现同名的情况
- 7.不能使用callee||caller
- 8.不能使用eval和arguments作为标识符(变量和函数的名称)
- 9.修正了this的指向
function func(){
console.log(this);
}
func();
默认情况下,this指向的是window,严格模式下this指向的是undefind
在默认情况下,如果函数内部形参被重新设置,那么arguments也会跟着改变
在严格模式情况下,如果函数内部形参被重新设置,那么arguments不会被改变,他们是相互独立的。
值类型的数据作为函数的参数
引用类行的数据作为函数的参数
作用域
- “ues strict”的位置:当前作用域的最顶端
(只会对当前作用域有影响)
- js中的作用域:
- script:全局作用域
- 函数内部:局部作用域
- 作用域:
- 概念:变量或者是函数起作用的范围。
- js的作用域:
- js本身没有块级作用域
- js中只有函数可以创建作用域
- js本身是词法作用域(with||eval)
- 词法作用域:当代码写好之后,某个变量的作用域就已经确定了
- 访问规则:
1.单向性的(单向镜)内部的作用域可以访问外层的作用域空间,反过来却不行
2.在访问变量的时候,在先前作用域中查找,如果找不到那么就在上级作用域中查找,重复这个过程
3.在分析输出的时候,需要考虑到变量和函数声明的提升
- 动态作用域:变量的作用域在代码运行之前是不确定的,只有在代码执行的时候才会根据上下文确定
var demo = "测试";
function fi(){
var demo = "demo";
f2();
}
function f2(){
console.log(demo);
}
f2() //测试
f1() //测试
- js代码的执行
- 编译语言
- 脚本语言(解释性的语言)
1.预先解析阶段
变量和声明的提升
2.具体执行的代码
- js变量和函数声明的提升
- 注意点:
变量和变量同名,后面的变量会把前面的变量覆盖
函数和函数同名,后面覆盖前面
变量和函数同名,函数声明会正常的提升,而变量的声明可以认为被忽略了。
1.在执行代码之前,会把所有的变量和函数声明进行提升
2.在提升的时候,变量和函数生明的提升是分作用域的,只能提升到当前作用域的顶端。
3.内层作用域中的变量声明并不会覆盖外层作用域的同名变量
- 函数表达式的提升
- 如果是函数表达式提升,那么在提升的时候仅仅只会把声明的部分(var fun)提升到当前作用域的顶端
- 作用域链
- 在JS中函数可以创建作用域,在函数内部又可以声明函数,-->。
1.在访问变量的时候,总是先在自己的作用域中查找
2.如果没有就向上一级查找,找到的话直接使用,没有继续查找
3.直到最外层的全局作用域
- 作用域数量:函数的个数加1
- 内层的作用域可以访问外层的作用域,外层的作用域不可以访问内层的
- 相同的作用域可以相互访问