JS性能优化

每当将事件处理程序指定给一个元素是,运行中的浏览器与支持页面交互的JavaSctipt代码之间就会建立一个连接。这种连接越多,页面执行起来就越慢。
1.可以采用事件委托技术,限制连接数量!
好处: 只指定一个事件处理程序,就可以管理某一类型的所有事件。例如,click事件会一直冒泡到document层次。也就是说,我们可以为整个页面指定一个onclick事件处理程序,而不必给每个单击的元素分别添加事件处理程序。
这样就可以大大减少运行中的浏览器和支持页面交互的JavaScript的连接数,页面会执行的更快。
<ul id="myLinks" >
    <li id="goSomewhere">go Somewhere</li>
    <li id="doSomething">do Something</li>
    <li id="sayHi">say Hi</li>
</ul>

按照传统的做法,需要为它们添加三个事件处理程序。
var item1 = document.getElementById("goSomewhere");
var itme2 = document.getElementById("doSomething");
var item3 = document.getElementById("sayHi");

item1.onclick = function() {
    alert(this.id); // goSomewhere
};

item2.onclick = function() {
    alert(this.id); // doSomething
};

item3.onclick = function() {
    alert(this.id); // sayHi
};


这样只需要为一个元素指定一个处理程序,就可以处理三个元素的事件处理程序。优化了性能
var myLinks = document.getElementById("myLinks");
var handler = function(event) {
  var target =  event.target || event.srcElement;
  alert(targer.id);
};

myLinks.onclick = handler;


2.在不必要的时候,移除元素指定的事件处理程序。
不必要的时候:
      1.从文档中移除带有事件处理程序的元素。(这样移除元素也能阻止事件冒泡,目标元素在文档中是事件冒泡的前提)
<div id="myDiv">
    <button id="myBtn">Click Me</button>
</div>
var myBtn = document.getElementById("myBtn");
myBtn.onclick = function() {
    var myDiv = document.getElementById("myDiv");
    myDiv.innerHTML = "Porr.........";
}
    这里,有一个按钮被包含在<div>中。为避免双击,单击这个按钮时就将按钮移除并替换成一条消息;这是网站设计中非常流行的一种做法。但问题在于,当按钮被从页面中移除时,他还带着一个事件处理程序。在<div>元素上设置上设置innerHTML 可以把按钮移走,但事件处理程序仍然与按钮保持着引用关系。有些浏览器(尤其是IE)在这种情况下不会作出恰当地处理,它们很有可能会将对元素和对事件处理程序的引用保存在内存中。如果你知道某个元素即将被移除,那么最好手工移除事件处理程序。
<div id="myDiv">
    <button id="myBtn">Click Me</button>
</div>
var myBtn = document.getElementById("myBtn");
myBtn.onclick = function() {
    myBtn.onclick = null;
    var myDiv = document.getElementById("myDiv");
    myDiv.innerHTML = "Porr.........";
}
在此,我们设置<div>的innerHTML属性之前,先移除了按钮的事件处理程序。这样就确保内存可以被再次利用,而从DOM中移除按钮也做到了干净利索。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值