javascript的性能优化tips
谈到javascript的性能优化,有好多点,比如把script放到离body闭合标签附近,合并多个script标签等等,还有一些代码的性能,for的性能不如while的性能好,用while模拟for循环等等等。
1.从加载开始
在浏览器中,js文件的执行和下载会阻塞css和dom的渲染,这是浏览器的单线程所致,后来chrome,ff等浏览器启用了
js文件的并行下载,然而js文件的运行还是会被阻塞,有的浏览器支持defer关键字。
<script type="text/javascript" defer>
alert("defer");
</script>
<script type="text/javascript">
alert("ok")
</script>
<script type="text/javascript">
window.onload=function(){
alert("onload");
}
</script>
不支持defer的浏览器会输出defer,ok,onload,支持的会弹出ok,defer和onload,defer是在dom渲染之前的。
还可以把js文件的script标签用js动态加载。这样文件的下载执行就不会影响其他页面的处理过程。
另外,你可以监听script标签load事件,而ie触发一个readystatechange事件,而且有一个readyState,
它有5个状态,最主要的就是loaded和complete事件,然而ie的这两个事件表现又不一致,有时候又loaded事件没有complete,有时候反之。
那我们在用的时候就可以同时判断:
var script=document.createElement("script");
script.type="text/javascript";
script.onreadystatechange=function(){
if (script.readyState=="loaded"||script.readyState=="complete") {
script.onreadystatechange=null;//为了防止事件处理两次
alert("script ok");
};
}
script.src="file.js";
document.body.append(script);
2.数据存储的优化
如果外部数据在函数作用域内多次使用,最好用一个局部变量来表示,因为局部变量在函数作用域内的性能消耗是最少的,
函数作用域链中优先查找局部变量,全局变量的性能消耗相对较多。
var a=doucument.getElementById("aa");
document.body.onclick=function(){
var temp=a;
// temp to do something...
}
3.dom操作的优化
javascript中存在的dom集合,如document.getElementsByTagName(''),document.links,document.images,document.forms,
document.forms[0].elements,他们都是类数组,有一个length属性,而在遍历的时候会重新查找计算,而把它们放到一个真正的数组里是一个优化方案。
或者可以把length用一个变量表示一下;
var col=document.getElementsByTagName('div');
var len=col.length;
for (var i = 0; i < len; i++) {
//todo;
};
在选择dom的结构中,firstChild,nextSibling,previousSibling都是包含文本节点和注释节点,比如在我以前写的选择dom里面,就写了好几个nextSibling。在选取子元素的时候nextSibling比childNodes性能更节省,在ie下节省的性能更多,而jquery的children里面也是用的nextSibling选取的。
下面这个结构,img1的nextSibling是文本节点,如果自己过滤的话会产生性能消耗,现代浏览器提供了nextElementSibling,previousElementSibling等等,他们可以自动过滤文本节点和注释节点,从而提升性能,
ie6,7,8只支持children。
<img src="" id="img1">
<!-- zhushi -->
<img src="" id="img2">
在dom的选择中,querySelectorAll的特性比getElementById的性能好,比如这个结构里:
var b=document.querySelectorAll('img#img1,img#img2');
querySelectorAll比较方便,而循环迭代getElementById的性能就不怎么样了。浏览器支持就用吧。
4.for循环的优化
for循环的优化,在迭代1000次以上,用达夫设备比较快,基本思想就是用while代替for。而forEach比for循环还慢;
if else和switch相比,在条件多的时候用 switch条件少用if else 这也符合性能的考虑。
递归的优化,可以将递归转化为迭代。为了防止递归做一些重复的计算,可以建立缓存如下,视实际情况选用。称为制表技术。这里给一个制表技术的例子:
function merta(n){
if (!merta.cache) {
merta.cache={
0:0,
1:1
}
};
if (!merta.cache.hasOwnProperty(n)) {
merta.cache[n]=n*merta(n-1);
};
return merta.cache[n];
}
求数字的阶乘,每次递归的结果都被缓冲,从而达到节省性能。
5.字符串的优化
str+="one"+"two";
在运行的时候会产生一个临时变量="onetwo",然后让这个临时变量+=str,而str=str+'one'+'two',就会阻止临时变量的产生,从而做到优化。在大多数浏览器会加快10%-40%
在ie中,这些优化并不适用,ie的字符串处理机制不用,在ie8中连接字符串只会记下各个字符串的引用,在连接的时候把各个字符串拷贝到真正的字符串中,并取代它的引用。
而ie8以前的实现更糟,这种方法反而会使效率更慢。ie8以前给每一个字符串的拷贝分配空间,在大量字符串连接的时候性能消耗成倍增长,只能用数组的连接方法来达到优化
while(len--){
newstr[newstr.length]=str;
}
newStr=newstr.join('');
javascript的性能优化tips的更多相关文章
- JavaScript代码性能优化总结
JavaScript 代码性能优化总结 尽量使用源生方法 javaScript是解释性语言,相比编译性语言执行速度要慢.浏览器已经实现的方法,就不要再去实现一遍了.另外,浏览器已经实现的方法在算法方面 ...
- 【转】js JavaScript 的性能优化:加载和执行
JavaScript 的性能优化:加载和执行 转自:https://www.ibm.com/developerworks/cn/web/1308_caiys_jsload/ 随着 Web2.0 技术的 ...
- JavaScript 的性能优化:加载和执行
随着 Web2.0 技术的不断推广,越来越多的应用使用 javascript 技术在客户端进行处理,从而使 JavaScript 在浏览器中的性能成为开发者所面临的最重要的可用性问题.而这个问题又因 ...
- [转]JavaScript 的性能优化:加载和执行
原文链接:http://www.ibm.com/developerworks/cn/web/1308_caiys_jsload/index.html?ca=drs- JavaScript 的性能优化: ...
- javascript循环---性能优化
循环是编程中是最为常见的结构,优化循环是性能优化中很重要的一个部分. 减值迭代:大多数循环使用一个从0开始.增加到某个特定值的迭代器.在很多情况下,从最大值开始,在循环中不断减值的迭代器更加高效. 简 ...
- Android应用程序性能优化Tips
对于我们设计的应用需要做到以下特征:build an app that's smooth, responsive(反应敏捷), and uses as little battery as possib ...
- Javascript常见性能优化
俗话说,时间就是生命,时间就是金钱,时间就是一切,人人都不想把时间白白浪费,一个网站,最重要的就是体验,而网站好不好最直观的感受就是这个网站打开速度快不快,卡不卡. 当打开一个购物网站卡出翔,慢的要死 ...
- JavaScript的性能优化:加载和执行
随着 Web2.0 技术的不断推广,越来越多的应用使用 javascript 技术在客户端进行处理,从而使 JavaScript 在浏览器中的性能成为开发者所面临的最重要的可用性问题.而这个问题又因 ...
- JavaScript code 性能优化
1 1 1 JavaScript 性能优化 prototype 闭包 Closure 内存泄漏 event system 1 定义类方法以下是低效的,因为每次构建baz.Bar的实例时,都会为foo创 ...
随机推荐
- [转帖] bat方式遍历目录内的文件
https://blog.csdn.net/qq_34924407/article/details/82781956 知识挺好用的 学习一下. #所有文件,包括子目录下的文件 @echo offcd ...
- java内部类 和外部类的区别
java 内部类和静态内部类的区别 详细连接https://www.cnblogs.com/aademeng/articles/6192954.html 下面说一说内部类(Inner Class)和 ...
- PDO连接mysql数据库加载慢
今天在使用PDO连接mysql操作数据库的时候,发现速度特别慢,都1~2s的时间,不知道怎么回事,后来一步一步排除到new PDO 导致过慢的原因, 这个尴尬了...,调试了半天都没想到问下度娘,才知 ...
- 将大数组里面的小数组平行展开的实现(Making a flat list out of list of lists in Python)
今天在生成数据的时候遇到了这个需求,其实写一个for循环可以很容易解决这个问题,但是无论是性能还是酷炫程度上都不行 所以顺手搜索了一下. 例子是将 l = [[1, 2, 3], [4, 5, 6], ...
- jenkins中通过execute shell启动的进程会被杀死的问题
在jenkins中配置自动更新部署项目时,如果采取用execute shell启动/关闭tomcat,会发现可以进行关闭tomcat, 但是无法启动tomcat,虽然构建会显示执行成功,但是查看进程, ...
- Shell 编程和Python编程的那些不同之处(一)
循环 shell中for循环的表现形式: 1.数字段形式 for i in {1..10};do echo $i;done 还支持按规定的步数进行跳跃的方式实现列表for循环,例如计算1-100内所 ...
- SVG路径
前面的话 本文将详细介绍SVG路径 path字符串 路径(path)是一个非常强大的绘图工具,可以用path元素绘制矩形(直角矩形或者圆角矩形).圆形.椭圆.折线形.多边形,以及一些其他的形状,例如贝 ...
- Vue入门基础
前面的话 Vue中文文档写得很好,界面清爽,内容翔实.但文档毕竟不是教程,文档一上来出现了大量的新概念,对于新手而言,并不友好.个人还是比较喜欢类似于<JS高级程序设计>的风格,从浅入深, ...
- Random Processes
对于信号处理来说,有一类信号是非常重要的,这类信号就是随机信号(random signal),也被称为随机过程(random processes/stochastic processes).在各种书籍 ...
- HTML5获取地理位置信息
<!DOCTYPE html> <html> <head> <title>Location</title> <meta charset ...