javascript编程的最佳实践推荐
推荐的javascript编程的最佳实践,摘要记录在这里:
可维护的代码
保证代码的性能
部署代码
1 可维护的代码
1.1什么是维护的代码:
可理解性——其他人可以接手代码并理解它的意图和一般途径,而无需原开发人员的完整解释。
直观性——代码中的东西一看就能明白,不管其操作过程多么复杂。
可适应性——代码以一种数据上的变化不要求完全重写的方法撰写。
可扩展性——在代码架构上已考虑到在未来允许对核心功能进行扩展。
可调试性——当有地方出错时,代码可以给予你足够的信息来尽可能直接地确定问题所在。
1.2 代码约定:
可读性
变量和函数命名
命名的一般规则如下所示:
变量名应为名词如 car 或 person。
函数名应该以动词开始,如 getName()。返回布尔类型值的函数一般以 is 开头,如isEnable()。
变量和函数都应使用合乎逻辑的名字,不要担心长度。长度问题可以通过后处理和压缩来缓解。
变量类型透明
1.3 松散耦合
解耦 HTML/JavaScript
解耦 CSS/JavaScript
解耦应用逻辑/事件处理程序
1.4 编程实践
尊重对象所有权
不要为实例或原型添加属性
不要为实例或原型添加方法
不要重定义已存在的方法
创建包含所需功能的新对象,并用它与相关对象进行交互
创建自定义类型,继承需要进行修改的类型。然后可以为自定义类型添加额外功能。
避免全局量
最多创建一个全局变量,让其他对象和函数存在其中,单一的全局量的延伸便是命名空间的概念
避免与 null 进行比较,如果看到了与 null 比较的代码,尝试使用以下技术替换
如果值应为一个引用类型,使用 instanceof 操作符检查其构造函数
如果值应为一个基本类型,使用 typeof 检查其类型
如果是希望对象包含某个特定的方法名,则使用 typeof 操作符确保指定名字的方法存在于对象上。
代码中的 null 比较越少,就越容易确定代码的目的,并消除不必要的错误。
使用常量
重复值
用户界面字符串
URLs
任意可能会更改的值
2. 性能
2.1 注意作用域
避免全局查找
避免 with 语句
2.2 选择正确方法
避免不必要的属性查找,最简单、最快捷的算法是常数值即 O(1)
优化循环
减值迭代
简化终止条件
简化循环体
使用后测试循环
展开循环,考虑使用一种叫做 Duff 装置的技术
//credit: Jeff Greenberg for JS implementation of Duff’s Device
//假设 values.length > 0
var iterations = Math.ceil(values.length / 8);
var startAt = values.length % 8;
var i = 0;
do {
switch(startAt){
case 0: process(values[i++]);
case 7: process(values[i++]);
case 6: process(values[i++]);
case 5: process(values[i++]);
case 4: process(values[i++]);
case 3: process(values[i++]);
case 2: process(values[i++]);
case 1: process(values[i++]);
}
startAt = 0;
} while (--iterations > 0);
//credit: Speed Up Your Site (New Riders, 2003)
var iterations = Math.floor(values.length / 8);
var leftover = values.length % 8;
var i = 0;
if (leftover > 0){
do {
process(values[i++]);
} while (--leftover > 0);
}
do {
process(values[i++]);
process(values[i++]);
process(values[i++]);
process(values[i++]);
process(values[i++]);
process(values[i++]);
process(values[i++]);
process(values[i++]);
} while (--iterations > 0);
避免双重解释, eval("alert('Hello world!')"); setTimeout("alert('Hello world!')", 500);
性能的其他注意事项
原生方法较快
Switch 语句较快, 还可以通过将 case 语句按照最可能的到最不可能的顺序进行组织
位运算符较快 诸如取模,逻辑与和逻辑或都可以考虑用位运算来替换。
2.3 最小化语句数
多个变量声明,var count = 5, color = "blue", values = [1,2,3], now = new Date(); 变量声明只用了一个 var 语句,要比单个变量分别声明快很多。
插入迭代值
使用数组和对象字面量
2.4 优化DOM交互
最小化现场更新,即不要频繁的动态修改或生成DOM
使用 innerHTML
使用事件代理
注意 HTMLCollection,编写 JavaScript 的时候,一定要知道何时返回 HTMLCollection 对象
3 部署
3.1 构建过程
知识产权问题
文件大小
代码组织
记住通过<script>标记引用 JavaScript 文件是一个阻塞操作
使用 Ant进行 JavaScript 和 CSS 的构建自动化
<project name="JavaScript Project" default="js.concatenate">
<!-- 输出的目录 -->
<property name="build.dir" value="./js" />
<!-- 包含源文件的目录 -->
<property name="src.dir" value="./dev/src" />
<!-- 合并所有 JS 文件的目标 -->
<!-- Credit: Julien Lecomte, http://www.julienlecomte.net/blog/2007/09/16/ -->
<target name="js.concatenate">
<concat destfile="${build.dir}/output.js">
<filelist dir="${src.dir}/js" files="a.js, b.js"/>
<fileset dir="${src.dir}/js" includes="*.js" excludes="a.js, b.js"/>
</concat>
</target>
</project>
# ant js.concatenate
3.2 验证
有些工具可以帮助确定 JavaScript 代码中潜在的问题,其中最著名的就是 Douglas Crockford 的 JSLint (www.jslint.com)。
JSLint 可以查找 JavaScript 代码中的语法错误以及常见的编码错误。
eval()的使用;
未声明变量的使用;
遗漏的分号;
不恰当的换行;
错误的逗号使用;
语句周围遗漏的括号;
switch 分支语句中遗漏的 break;
重复声明的变量;
with 的使用;
错误使用的等号(替代了双等号或三等号);
无法到达的代码。
它也可以使用基于Java的Rhino JavaScript引擎(www.mozilla.org/rhino/)运行于命令行模式下
# java -jar rhino-1.6R7.jar jslint.js a.js b.js c.js
<target name="js.verify">
<apply executable="java" parallel="false">
<fileset dir="${build.dir}" includes="output.js"/>
<arg line="-jar"/>
<arg path="${rhino.jar}"/>
<arg path="${jslint.js}" />
<srcfile/>
</apply>
</target>
# ant js.verify
这个目标假设 Rhino jar 文件的位置已经由叫做 rhino.jar 的属性指定了,同时 JSLint Rhino 文件的位置由叫做 jslint.js 的属性指定了。output.js 文件被传递给 JSLint 进行校验,然后显示找到的任何问题。
3.3 压缩
文件压缩
删除额外的空白(包括换行);
删除所有注释;
缩短变量名。
YUI 压缩器,http://yuilibrary.com/projects/yuicompressor
java -jar yuicompressor-2.3.5.jar -o cookie.js CookieUtil.js
<!-- Credit: Julien Lecomte, http://www.julienlecomte.net/blog/2007/09/16/ -->
<target name="js.compress">
<apply executable="java" parallel="false">
<fileset dir="${build.dir}" includes="output.js"/>
<arg line="-jar"/>
<arg path="${yuicompressor.jar}"/>
<arg line="-o ${build.dir}/output-min.js"/>
<srcfile/>
</apply>
</target>
# ant js.compress
HTTP 压缩
对于 Apache Web服务器,
for apache 1.3 httpd.conf 文件或者是.htaccess 文件添加 mod_gzip_item_include file \.js$
for apache 2.0 AddOutputFilterByType DEFLATE application/x-javascript
javascript编程的最佳实践推荐的更多相关文章
- (译) 《Javascript 24条最佳实践》
(摘录) <Javascript 24条最佳实践> 自己一直偏向于实用主义,不是学院派,不是学究派,只讲究把东西能够很好的做出来,但经过一段时间的开发工作当自己总结出来一些东西时,觉得挺有 ...
- 学习现代 JavaScript 编程的最佳教程
天天编码 , 版权所有丨本文标题:0.0 学习现代 JavaScript 编程的最佳教程 转载请保留页面地址:http://www.tiantianbianma.com/the-modern-java ...
- 【转】超实用的JavaScript技巧及最佳实践
众所周知,JavaScript是一门非常流行的编程语言,开发者用它不仅可以开发出炫丽的Web程序,还可以用它来开发一些移动应用程序(如PhoneGap或Appcelerator),它还有一些服务端实现 ...
- 超实用的JavaScript技巧及最佳实践
众所周知,JavaScript是一门非常流行的编程语言,开发者用它不仅可以开发出炫丽的Web程序,还可以用它来开发一些移动应用程序(如PhoneGap或Appcelerator),它还有一些服务端实现 ...
- 超实用的JavaScript技巧及最佳实践(上)
在这篇文章中,作者将会向大家分享JavaScript开发的小技巧.最佳实践等非常实用的内容,不管你是前端开发者还是服务端开发者,都应该来看看这些小技巧,它们绝对会让你受益的. 文中所提供的代码片段都已 ...
- JavaScript Web 应用最佳实践分析
[编者按]本文作者为 Mathias Schäfer,旨在回顾在客户端大量使用JavaScript 的最佳 Web应用实践.文章系国内 ITOM 管理平台 OneAPM 编译呈现. 对笔者来说,Jav ...
- python高级编程之最佳实践,描述符与属性01
# -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrator' #最佳实践 """ 为了避免前面所有的 ...
- Javascript继承之最佳实践
尊重原创,转载请注明出处:http://blog.csdn.net/zoutongyuan 什么是继承? 继承是面向对象最显著的一个特性.继承是从已有的类中派生出新的类,新的类能吸收已有类的数据属性和 ...
- jQuery编程的最佳实践
好像是feedly订阅里看到的文章,读完后觉得非常不错,译之备用,多看受益. 加载jQuery 1.坚持使用CDN来加载jQuery,这种别人服务器免费帮你托管文件的便宜干嘛不占呢.点击查看使用CDN ...
随机推荐
- Classes and Objects :类和对象(1)
类的定义:修饰符,class,类名,extends,逗号分隔的implements,类体{}规范的类名:首字母要大写,以后每个单词首字母都大写字段的定义:修饰符,类型,字段名按照封装的思想,字段通常定 ...
- java动态代理与老式AOP实现
JAVA的动态代理 代理模式是常用的java设计模式,他的特征是代理类与委托类有同样的接口,代理类主要负责为委托类预处理消息.过滤消息.把消息转发给委托类,以及事后处理消息等.代理类与委托类之间通常会 ...
- CentOS上firefox安装flash
CentOS下firefox安装flash说明 CentOS下自带了firefox,但没有flash插件的,按它自己的提示安装不成功,需要手动安装,如下: 1.打开flash官网,http://lab ...
- TreeMap实现原理
摘要 研究项目底层代码时,发现项目中的数据的缓存用的是TreeMap来实现对数据的缓存管理.本片博文就TreeMap的源码.原理以及用法做一个探究 在用TreeMap之前我们要对TreeMap有个整体 ...
- Web Service学习之九:Restful WebService
1.Rest 2.Rest webService 3.SpringMVC Restful 参考: http://spring.io/guides/gs/rest-service/ http://www ...
- Gym 100507A About Grisha N. (水题)
About Grisha N. 题目链接: http://acm.hust.edu.cn/vjudge/contest/126546#problem/A Description Grisha N. t ...
- BestCoder Round #65 hdu5591(尼姆博弈)
ZYB's Game Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total ...
- ASP.NET MVC中Session以及处理方式
转载原地址 http://www.cnblogs.com/darrenji/p/3951065.html
- opencv 模板匹配与滑动窗口(单匹配) (多匹配)
1单匹配: 测试图片: code: #include <opencv\cv.h> #include <opencv\highgui.h> #include <open ...
- mac 下对 iterm 终端 设置代理
vi .profile export http_prox="http://xxxx:port" export https_proxy="http://xxxx:port& ...