Javascript 代码也可以变得优美
lems, eventName, handler) { var i = -1, len = elems.length; if (window.attachEvent) { eventName = “on” + eventName; while (++i < len) { elems[i].attachEvent(eventName, handler); } } else if (window.addEventListener) { while (++i < len) { elems[i].addEventListener(eventName, handler, false); } } } 2.2 尽量使用原生的函数而不是自定义函数当你对Javascript的内置类型变量执行某项操作时,你应该先查查这项操作是否有原生的方法。 要生成一个数组的副本,你会怎么做呢?遍历数组元素然后逐个赋值到另一个数组,这似乎是唯一的方法。其实,原生的Array.prototype.slice就可以达到复制的目的。这个方法可以从某个数组返回选定的元素,且不影响原来的数组。如果参数留空,返回的就是全部元素。 Array.prototype.slice还可以对某些不是数组而又能通过数字索引访问的类型进行操作,比如arguments: arguments: 在Firefox下,它甚至可以对HtmlCollection进行操作。可惜在IE下不行。 另一个例子是数组排序,一般情况下,我们不需要另外写排序算法,用原生的Array.prototype.sort就够了。sort方法只有一个参数,该参数是一个函数,决定两个相比较的元素谁在前谁在后,默认是按照字符顺序排序,比如11会排在2之前。要按数字大小排序,可以这样写: var arr = [11, 2, 0, 12, 33]; |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |