javascript优化
javaScript是一门解释性的语言、它不像java、C#等程序设计语言、由编译器先进行编译再运行、而是直接下载到用户的客户端进行执行。因此代码本身的优劣就直接决定了代码下载的速度以及执行的效率。
1、减缓代码下载时间:
Web浏览器下载的是javaScript的源码、其中包含的长变量名、注释、空格和换行等多余字符大大减缓了代码下载的时间。这些字符对于团队编写时十分有效、但在最后工程完成上传到服务器时、应当将它们全部删除。例如:
- function showMeTheMoney(){
- if(!money){
- return false;
- }else{
- ...
- }
- }
- function showMeTheMoney(){
- if(!money){
- return false;
- }else{
- ...
- }
- }
可优化成:
- function showMeTheMoney(){if(!money){return false;}else{...}}
- function showMeTheMoney(){if(!money){return false;}else{...}}
这样、优化后就节约了25个字节、倘若是一个大的javaScript工程、将节省出非常大的空间、不但提高了用户的下载速度、也减轻了服务器的压力。相信这样的代码大家见过不少、很多优秀的js插件源码都这么干!
另外、对于布尔型的值true和false、true都可以用1来代替,而false可以用0来代替。对于true节省了3个字节、而false则节省了4个字节、例如
- var bSearch = false;
- for(var i=0;i<aChoices.length&&!bSearch;i++){
- if(aChoices[i] == vValue)
- bSearch = true ;
- }
- var bSearch = false;
- for(var i=0;i<aChoices.length&&!bSearch;i++){
- if(aChoices[i] == vValue)
- bSearch = true ;
- }
替换成:
- var bSearch = 0;
- for(var i=0;i<aChoices.length&&!bSearch;i++){
- if(aChoices[i] == vValue)
- bSearch = 1 ;
- }
- var bSearch = 0;
- for(var i=0;i<aChoices.length&&!bSearch;i++){
- if(aChoices[i] == vValue)
- bSearch = 1 ;
- }
替换了布尔值之后、代码的执行效率、结果都相同、但节省了7个字节。
代码中常常会出现检测某个值是否为有效值的语句、而很多条件非的判断就判断某个变量是否为"undefined"、"null"、或者"false"、例如:
- if(myValue != undefined){
- //...
- }
- if(myValue !=null){
- //...
- }
- if(myValue != false){
- //...
- }
- if(myValue != undefined){
- //...
- }
- if(myValue !=null){
- //...
- }
- if(myValue != false){
- //...
- }
这些虽然都正确、但采用逻辑非操作符"!"也可以有同样的效果、代码如下:
- if(!myValue){
- //...
- }
- if(!myValue){
- //...
- }
这样的替换也可以节省一部分字节、而且不太影响代码的可读性。类型的代码优化还有将数组定义时的 new Array()直接用"[]"代替、对象定义时的 new Object()用"{}"代替等、例如:
- var myArray = new Array();
- var myArray = [];
- var myObject = new Object();
- var myObject = {};
- var myArray = new Array();
- var myArray = [];
- var myObject = new Object();
- var myObject = {};
显然、第二行和第四行的代码较为精简、而且也很容易理解。
另外、在编写代码时往往为了提高可读性、函数名称、变量名称使用了很长的英文单词、同时也大大增加了代码的长度、例如:
- function AddThreeVarsTogether(firstVar,secondVar,thirdVar){
- return (firstVar+secondVar+thirdVar);
- }
- function AddThreeVarsTogether(firstVar,secondVar,thirdVar){
- return (firstVar+secondVar+thirdVar);
- }
可优化成:
- function A(a,b,c){return (a+b+c);}
- function A(a,b,c){return (a+b+c);}
注意:在进行变量名称替换时、必须十分小心、尤其不推荐使用文本编辑器的"查找"、"替换"功能、因为编辑器不能很好地区分变量名称或者其他代码。例如、希望将变量"tion"全部替换成"io"、很可能导致关键字"function"也被破坏。
对于上面说的这些减少代码体积的方法、有一些很实用的小工具可以自动完成类似的工作、例如ECMAScript Cruncher、JSMin、Online JavaScript Compressor等。
2、合理声明变量
减少代码的体积仅仅只能使得用户下载的速度变快、但执行程序的速度并没有改变。要提高代码执行的效果、还得在各方面做调整。
在浏览器中、JavaScript默认的变量范围是window对象、也就是全局变量。全局变量只有在浏览器关闭才释放。而JavaScript也有局部变量、通常在function中执行完毕就会立即被释放。因此在函数体中要尽可能使用var关键字来声明变量:
- function First(){
- a = "" ; //直接使用变量
- }
- function Second(){
- alert(a);
- }
- First();
- Second();
- function First(){
- a = "" ; //直接使用变量
- }
- function Second(){
- alert(a);
- }
- First();
- Second();
这样、变量"a"就成为了全局变量、直到页面关闭时才会被销毁、浪费了不必要的资源、如果在"a"的前面加上"var"、这样"a"就成为了当前function的局部变量。在执行完First()便立即被销毁。因此、在函数体中、如果不是特别需要的全局变量、都应当使用"var"进行声明、从而节省系统资源。
3、使用内置函数缩短编译时间
只要可能、应当尽量使用JavaScript的内置函数。因为这些内置的属性、方法都是用类似C、C++之类的言语编译过的、运行起来比实时编译的JavaScript快很多。例如计算指数函数、可以自己编写:
- <html>
- <head>
- <base href="<%=basePath%>">
- <title>内置函数</title>
- <meta http-equiv="pragma" content="no-cache">
- <meta http-equiv="cache-control" content="no-cache">
- <meta http-equiv="expires" content="0">
- <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
- <meta http-equiv="description" content="This is my page">
- <script type="text/javascript">
- function myPower(iNum,n){
- var iResult = iNum ;
- for(var i=0;i<n;i++)
- iResult *= iNum ;
- return iResult;
- }
- var myDate1 = new Date();
- for(var i=0;i<150000;i++){
- myPower(7,8); //自定义方法
- }
- var myDate2 = new Date();
- document.write(myDate2 - myDate1);
- document.write("<br/>");
- myDate1 = new Date();
- for(var i=0;i<150000;i++){
- Math.pow(7,8); //采用系统内置方法
- }
- myDate2 = new Date();
- document.write(myDate2 - myDate1);
- </script>
- </head>
- <body>
- </body>
- </html>
- <html>
- <head>
- <base href="<%=basePath%>">
- <title>内置函数</title>
- <meta http-equiv="pragma" content="no-cache">
- <meta http-equiv="cache-control" content="no-cache">
- <meta http-equiv="expires" content="0">
- <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
- <meta http-equiv="description" content="This is my page">
- <script type="text/javascript">
- function myPower(iNum,n){
- var iResult = iNum ;
- for(var i=0;i<n;i++)
- iResult *= iNum ;
- return iResult;
- }
- var myDate1 = new Date();
- for(var i=0;i<150000;i++){
- myPower(7,8); //自定义方法
- }
- var myDate2 = new Date();
- document.write(myDate2 - myDate1);
- document.write("<br/>");
- myDate1 = new Date();
- for(var i=0;i<150000;i++){
- Math.pow(7,8); //采用系统内置方法
- }
- myDate2 = new Date();
- document.write(myDate2 - myDate1);
- </script>
- </head>
- <body>
- </body>
- </html>
我运行的结果是、自定义方法用了15、内置方法用了1(不同的计算机运行速度会有差别)、这样就能看出、系统内置的方法要快很多。
4、合理书写if语句。
if语句恐怕是所有代码中使用最频繁的、然而很可惜的是它的执行效率并不是很高。在用if语句和多个else语句时、一定要把最有可能的情况放在第一个、然后是可能性第二的、依此类推。例如预计某个数值在0~100之间出现的概率最大、则可以这样安排代码:
- if(iNum>0&&iNum <100){
- alert("在0和100之间");
- }else if(iNum>99&&iNum<200){
- alert("在100和200之间");
- }else if(iNum>199&&iNum<300){
- alert("在200和300之间");
- }else{
- alert("小于等于0或者大于等于300");
- }
- if(iNum>0&&iNum <100){
- alert("在0和100之间");
- }else if(iNum>99&&iNum<200){
- alert("在100和200之间");
- }else if(iNum>199&&iNum<300){
- alert("在200和300之间");
- }else{
- alert("小于等于0或者大于等于300");
- }
总是将出现概率最多的情况放在前面、这样就减少了进行多次测试后才能遇到正确条件的情况。当然也要尽可能减少使用else if 语句、例如上面的代码还可以进一步优化成如下代码:
- if(iNum>0){
- if(iNum<100){
- alert("在0和100之间");
- }else{
- if(iNum<200){
- alert("在100和200之间");
- }else{
- if(iNum<300){
- alert("在200和300之间");
- }else{
- alert("大于等于300");
- }
- }
- }
- }else{
- alert("小于等于0");
- }
- if(iNum>0){
- if(iNum<100){
- alert("在0和100之间");
- }else{
- if(iNum<200){
- alert("在100和200之间");
- }else{
- if(iNum<300){
- alert("在200和300之间");
- }else{
- alert("大于等于300");
- }
- }
- }
- }else{
- alert("小于等于0");
- }
上面的代码看起来比较复杂、但因为考虑了很多代码潜在的判断问题、执行问题、因此执行速度要较前面的代码快。
另外、通常当超过两种情况时、最好能够使用switch语句。经常用switch语句代替if语句、可令执行速度快甚至10倍。另外、由于case语句可以使用任何类型、也大大方便switch语句的编写。
5、最小化语句数量
脚本找哦个的语句越少执行的时间就越短、而且代码的体积也会相应减少。例如使用var定义变量时可以一次定义多个、代码如下
- var iNum = 365;
- var sColor = "yellow";
- var aMyNum = [8,7,12,3] ;
- var oMyDate = new Date();
- var iNum = 365;
- var sColor = "yellow";
- var aMyNum = [8,7,12,3] ;
- var oMyDate = new Date();
上面的多个定义可以用var关键字一次性定义、代码如下:
- var iNum = 365, sColor = "yellow" , aMyNum = [8,7,12,3],oMyDate = new Date() ;
- var iNum = 365, sColor = "yellow" , aMyNum = [8,7,12,3],oMyDate = new Date() ;
- var iNum = 365, sColor = "yellow" , aMyNum = [8,7,12,3],oMyDate = new Date() ;
同样在很多迭代运算的时候、也应该尽可能减少代码量、如下两行代码:
- var sCar = aCars[i];
- i++;
- var sCar = aCars[i];
- i++;
可优化成:
- var sCar = aCars[i++];
- var sCar = aCars[i++];
6、节约使用DOM
JavaScript对DOM的处理可能是最耗费时间的操作之一。每次JavaScript对DOM的操作都会改变页面的表现、并重新渲染整个页面、从而有明显的时间消耗。比较快捷的方法就是尽可能不在页面进行DOM操作、如下例中为ul添加了10个条目
- var oUl = document.getElementById("ulItem");
- for(var i=0;i<10;i++){
- var oLi = document.createElement("li");
- oUl.appendChild(oLi);
- oLi.appendChild(document.createTextNode("Item "+i));
- }
- var oUl = document.getElementById("ulItem");
- for(var i=0;i<10;i++){
- var oLi = document.createElement("li");
- oUl.appendChild(oLi);
- oLi.appendChild(document.createTextNode("Item "+i));
- }
以上代码在循环中调用oUl.appendChild(oLi)、每次执行这条语句后、浏览器就会重新渲染页面、其次给列表添加文本节点oLi.appendChild(document.createTextNode("Item "+i))、这也会造成页面被重新渲染。因此每次运行都会造成两次重新渲染页面、共20次。
通常应当尽可能减少DOM的操作、将列表项目在添加文本节点之后在添加、并合理地使用createDocumentFragment()、代码如下:
- var oUl = document.getElementById("ulItem");
- var oTemp = document.createDocumentFragment();
- for(var i=0;i<10;i++){
- var oLi = document.createElement("li");
- oLi.appendChild(document.createTextNode("Item "+i));
- oTemp.appendChild(oLi);
- }
- oUl.appendChild(oTemp);
javascript优化的更多相关文章
- 前端网络、JavaScript优化以及开发小技巧
一.网络优化 YSlow有23条规则,中文可以参考这里.这几十条规则最主要是在做消除或减少不必要的网络延迟,将需要传输的数据压缩至最少. 1)合并压缩CSS.JavaScript.图片,静态资源CDN ...
- 前端性能优化(三)——传统 JavaScript 优化的误区
注:本文是纯技术探讨文,无图无笑点,希望您喜欢 一.前言 软件行业极其缺乏前端人才这是圈内的共识了,某种程度上讲,同等水平前端的工资都要比后端高上不少,而圈内的另一项共识则是--网页是公司的脸面! 几 ...
- Javascript 优化
Javascript 优化 作者:@gzdaijie本文为作者原创,转载请注明出处:http://www.cnblogs.com/gzdaijie/p/5324489.html 目录 1.全局变量污染 ...
- 5.JavaScript优化及导航菜单背后的秘密
JavaScript优化及导航菜单背后的秘密 伍星 学习目标1.进一步了解前端优化 学习如何编写良好的 JavaScirpt2.通过导航的学习,了解JavaScirpt的应用 JavaScript在用 ...
- Javascript优化细节:短路表达式
什么是短路表达式? 短路表达式:作为"&&"和"||"操作符的操作数表达式,这些表达式在进行求值时,只要最终的结果已经可以确定是真或假,求值过程 ...
- Javascript 优化项目代码技巧之语言基础(二)
上一篇随笔介绍了如何正确判断对象类型.避免变量污染,特殊值(null.undefined.NaN)的使用,以及其他Javascript中常用关键字与方法的优化,这篇随笔将着重介绍Javascr ...
- Javascript 优化项目代码技巧之语言基础(一)
Javascript的弱类型以及函数作用域等规则使用编写Javascript代码极为容易,但是编写可维护.高质量的代码却变得十分困难,这个系列的文章将总结在项目开发过程中,能够改善代码可读性. ...
- 对JavaScript优化及规范的一些感想
变量...... 1.一个变量只存一种类型的数据,2.尽量减少对隐式转换的依赖,这样可增强程序的可读性,日后修改程序时不至于混乱,3.使用匈牙利命名法,4.使用局部变量时记得加 var 进行声明,不然 ...
- javascript优化--13模式1(DOM和浏览器模式)
注意分离: 通过将CSS关闭来测试页面是否仍然可用,内容是否依然可读: 将JavaScript关闭来测试页面仍然可以执行正常功能:所有连接是否正常工作:所有的表单是否可以正常工作: 不使用内联处理器( ...
随机推荐
- [转] VS 整合NUnit进行单元测试
Jeff Wong原文 5分钟实现VS2010整合NUnit进行单元测试 1.下载安装NUnit(最新win版本为NUnit-2.6.0.12051.msi) http://www.nunit.org ...
- Yii系列教程(二):功能简介
1 MVC架构 1.1处理流程 一个Web请求在Yii内部的执行流程如下图所示: 1.2组件角色 组件名 角色与责任 index.php 入口脚本.创建Application的单例对象. applic ...
- 18、GPS技术
GPS核心API Android SDK为GPS提供了很多API,其中LocationManager类是这些API的核心.LocationManager是一个系统服务类,与TelephonyManag ...
- dll 打包
开发程序的时候经常会引用一些第三方的DLL,然后编译生成的exe文件就不能脱离这些DLL独立运行了. 但是,很多时候我们本想开发一款只需要一个exe就能完美运行的小工具.那该怎么办呢? 下文介绍一种超 ...
- 指针数组 数组指针的区别.xml
pre{ line-height:1; color:#1e1e1e; background-color:#f0f0f0; font-size:16px;}.sysFunc{color:#627cf6; ...
- c++中的 extern "C"(转载)
比如说你用C 开发了一个DLL 库,为了能够让C ++语言也能够调用你的DLL 输出(Export) 的函数,你需要用extern "C" 来强制编译器不要修改你的函数名. 通常, ...
- Embedded之memory test
1 main.c #include "led.h" #define BASE_ADDRESS (volatile datum *) 0x10000000 #define NUM_B ...
- android读取data下得数据
拥有Root权限的情况 adb shell su cd /data/data/com.package 然后就可以直接读取 没有Root的情况 adb shell run-as com.package ...
- windows程序移植linux
1,路径名统一用正斜杠“/”.(windows下正反斜杠都识别,linux只认正斜杠.) 2,统一使用UTF-8格式编码. vim中无法保存汉字时,可输入下列命令: :set fileencoding ...
- [POJ] #1005# I Think I Need a Houseboat : 浮点数运算
一. 题目 I Think I Need a Houseboat Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 97512 ...