201170215 night js

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的第一个参数是字符串会发生内存泄漏。

点击打开链接



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值