1.预解释的作用
1)可以了解不同情况,i值到底是什么?
2)可以知道带var和不带var
3)可以明白为何程序能正常执行?为何会报错?
2.什么是预解释:
在当前作用域下,在JS代码执行之前,浏览器会对带var和带function的进行提前声明或定义;
3.带var和带function的声明和定义是不同的;
带var的:只声明不定义;告诉浏览器,有这么一个变量,但是并没有赋值
带function的:声明+定义;不仅告诉浏览器,有这么一个变量,而且对变量进行了赋值;
4.作用域链:
当函数被调用的时候,会形成一个私有作用域,看私有作用域中,是否存在私有变量A:
1)如果有私有变量A:那么整个作用域中的A,跟外界没有任何关系;所有该作用域中的A,都是私有变量;
2)如果没有私有变量A:就会往上级作用域进行查找,找到的话,直接用,找不到继续找,一直找到window还没有,就会报错!;
5.私有变量有两种:
1.当前作用域下带var的;
2.形参;
6.函数执行有四步骤:
1.首先会形成一个私有作用域
2.形参赋值
3.与解释
4.代码从上到下的执行;
7.带var和不带var的区别:
带var:1)在全局作用域下,变量相当于window的全局属性 2)带var会进行预解释
不带var:1)相当于window的全局属性 2)重要:不带var不会进行预解释;
8.预解释无节操:
1)只对等号左边带var的声明,但不定义;
2)自执行函数不会进行预解释,只有执行到他的时候,声明+定义+调用同步完成
3)已经声明过的变量,不会进行重复声明
4)return后面的语句不会进行预解释,return下面的语句,虽然不执行,但会进行预解释;
5)条件判断语句中:无论条件是否成立,都会进行预解释
警示:不要在条件判断语句中,写函数的定义阶段
9.在预解释的时候,函数的优先级>变量
10.运算符的优先级:
算术运算符》比较运算符》逻辑运算符》赋值运算符,所以,以后遇到赋值的时候,一定要加括号;
11.内存和内存释放:
内存主要包含:堆内存和栈内存;
栈内存:全局作用域和私有作用域;
作用:提供了一个供JS代码执行的环境;里面放的是基本数据类型的数据;
堆内存:
作用:就是用来存放引用数据类型的数据:
对象数据类型:存放的是属性名和属性值;
函数数据类型:把函数体中的所有JS代码,作为字符串存在堆内存空间中
内存释放:
堆内存的释放:让变量指向空指针;
var obj={key:value}; obj=null;
栈内存的释放:
全局作用域:形成:当浏览器加载完页面的时候,会形成一个供JS代码执行的全局作用域;
释放:关闭页面、关闭浏览器;
私有作用域:形成:函数被调用的时候;
一般情况下,当函数执行完成的时候,都会默认进行释放,但是两种特殊情况除外:
1)不释放:当函数体中的任何东西,被外面的变量或者其他东西占用的时候,该函数不释放;
2)不立即释放:当函数执行完成的时候,返回一个需要执行的函数;需要等待所有的函数都执行完成的时候,该函数才能释放;
12.上级作用域:
跟函数在哪里调用无关,只跟该函数对应的堆内存在哪里开辟有关;
13.关于函数的几种写法:
1)var f=function (){alert(1)}
2)f=function (){alert(1)}
3)function f(){alert(1)}
f();当f被调用的时候,以上三种的调用结果一样;不同的就是他们预解释不同;
14. .和attribute的区别:
区别主要有两点:
1)获取的时候:标签上如果设置了自定义属性,我们通过.拿不到自定义属性的值,但是通过obj.getAttribute()可以拿到;
2)设置的时候:通过点设置的自定义属性,在标签上看不到,但是通过setAttribute设置的值,在标签上可以看到;
注意事项:.和attribute不要混合使用;
练习题
|
|