一,函数的3中角色:
1.函数
2.类 :实例 instanceof constructor prototype
3.普通对象:普通函数也有prototype,没有什么实用的意思;里面有对应的属性值;name ,length;
二,this的5中情况
1.自执行函数函数中的this是window;函数在那定义和执行没有任何关系;
2.给元素的绑定某个方法,事件触发,方法执行,方法中的this是当前的元素;
3.构造函数的this是当前函数的实例;
4.函数执行之前看看有没有点,点前面是谁,this就是谁;根据当前点前面的this对象去寻找对应的属性和方法;
5.可以使用apply,call,bind强制改变函数中的this,this使用中优先级最高;
但是以上的this都是非严格模式下;js中还有严格模式,
‘use strict’ 开启js中的严格模式:
区别:
1.执行函数的中的this是undefined;
2.函数执行,如果前面没有点,this就是undefined;
3.使用call,apply,call如果第一个参数不传值,是undefined,如果传递第一个参数是null,undefined,this就是null,undefined;
特点:严格模式下,如果没有确定执行的主体,this都是undefined,
而不是非严格模式下的window;
三。dom回流
当页面中的html结构发生改变,浏览器会吧所有的结构进行重新渲染,和计算,消耗性能,我们要减少dom回流,
dom重绘:
当页面中有一个元素的样式,颜色等,发生改变,浏览器会把这个元素的样式重新绘制一下,性能不太影响;