1、call() apply()。
func.call(thisObject,arg1,arg2);
func.apply(thisObject,[arg1,arg2]);
二者作用一样,都是为了动态改变this。
区别:call需要按顺序把参数传递进去。
apply后边的参数是数组形式,适用于不知道参数具体数目时。
2、内存泄漏。
定义:在代码中申请了一块内存,在程序运行完以后没有释放这块内存。操作系统以为程序还在用这块内存,实际上程序并没有在用,积累不用的内存,减缓电脑的运行速度。
哪些操作会引起:
1、页面上的元素被修改或替换时,若元素被绑定的事件未被移除,则会发生内存泄漏。
btn.οnclick=function(){
btn.οnclick=null;//加上此句,将事件移除,避免发生泄漏
btn.getElementById("tfs").innerHTML="balabala";
}
2、控制台日志
3、循环引用
function element(){
var tfs = document.getElementById("div1");
tfs.οnclick=function(){
alert("balabala");
}
}
上式是个闭包,里边tfs(js)-->div1(dom),div1.onclick(dom)-->tfs(js)发生了循环引用,在此过程中,dom在闭包释放前不会释放,闭包在dom释放前也不会释放,故二者均不会释放,发生内存泄漏。
又如:a创建b,b创建c,c创建b。则b 与 c之间互相创建,互相循环引用,发生内存泄漏。
4、setTimeOut的第一个参数是字符串会发生内存泄漏。