我觉得写好代码和作文章差不多,无外乎:工整、优雅、拒绝重复、惜字如金。下面提供几个小建议:
[1] 态度
对代码要有感情,每一行都应该尽心尽力,并且还要有把那些扔垃圾篓的代码再重写两遍的冲动——一旦有了这种冲动之后,什么都挡不住你,连吃喝拉撒时,问题都会浮现到你脑子里,你就会不由自主地解决它们……能对自己的代码提出怀疑本身就是一件了不起的事!加油!
[2] 少写代码
1.提前设计能有助于少写代码,增强全局感。而代码写得少还能防止失控——感觉不对时就应该停下来,腾出时间来思考,为什么会偏离最先的想法。所有符号各就各位。第一眼就是空格太少,下面推荐三个工具给大家:
2.Beautify JavaScript or HTML可以给你的代码格式化,记得用diff工具对照一下,格式化前后的区别;
SublimeLinter可以动态地在编写时给出JSHint提示(出错行高亮);
Grunt可以在文件变更时给出SHint检验(声音以及桌面通知);
一旦把lint校验做为提交代码的必要过程,排版就会有本质的提高。
[3] 遵行惯用法
a. 注释符号‘//’后应该空一格;
b. 防止变量提升,应先声明后使用(JSHint会提醒出‘_height’存在变量提升以及定义后未使用的错误);
c. 不应该使用硬编码,并且重复几次(ID后缀名可以定义到常量里,用大写字母);
d. 不应该有两个配置属性,含义不明(this.opts和this._options);
e. 若两次以上引用同一对象的属性,应该定义到局部变量再引用(var options = this._options);
f. 不应该同时使用两种属性命名风格(colModel和table_body);
g. 局部变量名应该尽可能短,而方法名应该尽可能完整(不应该同时即有fromatTpl又有parseTemplate);
h. 局部变量名不需要用下划线开头,仅对象私有属性和私有方法有此必要;
i. 变量名不需要带类型属性(_thdoms叫ths就好);
j. 使用JavaScript时,for循环基本可以避免(比如jQuery有$.each, $.map,$.filter, $.grep等等高阶函数可用);
k. jQuery对象名习惯以$开头,以便区分DOM对象;
o. jQuery查询应尽量使用ontext(如 this.$table = $('table', this.$element) );
p. jQuery DOM操作和原生DOM操作不应该混用(已经使用jQuery的情况,就应该坚持使用jQuery来操作DOM,避免丑陋的原生操作);
q. DOM元素构造出来,也不应该再到文档中查询一遍了(图上的构造太复杂,一眼真看不懂);
[4] 代码复查
把程序写正确还只是跨出了第一步。把代码交给你的同事和朋友复查,这是学习经验、共同提高 最快的办法。
[5] 代码风格及排版
虽然任何一种语言都没有任何约定的风格,但也总有一些不成文且喜闻乐见的习俗。以你的代码为例,给以下几个风格上的建议:
每个function之间多一空行,是的,除去注释外再多一空行;
适当加空格,比如if和后面的括号之间的空格、小括号和花括号之间的空格、冒号和function之间的空格等等;
风格上保持一致,你的代码里面有的地方+号和运算数之间有空格,有的则没有;
少用下划线开头的变量命名;
一段代码里,var语句可以合并在一起;
暂时不会再修改的function或object,先用编辑器折叠起来,看上去也会整洁很多;
黑色背景的Editor风格不错,不过关键字、注释、运算符等颜色上可以再调整,主要是为了防止审美疲劳,换个色调换个心情;
[6] 使用成熟的javascript代码库
1. 如果没看错的话,你可能是使用了jQuery吧(至少也有一个类似Sizzle或更简单的解析器,证据在倒数第十行左右)。所以,就尽可能避免使用原生的JavaScript DOM操作。
2. jQuery的$符号,以CSS Selector风格统一取代了各种getElement(s)ByXxx的接口,并且扩展性非常强,是很多设计模式思想的综合运用。
3. 当然原生DOM也有自己的优势(主要是执行效率),但是大部分时候,在开发效率、代码质量、执行效率的tradeoff中,jQuery还是最佳选择。此外也推荐下JavaScript MVC库、jQuery UI库等等。
[7] 转自:http://www.csdn.net/article/2012-12-06/2812544-How-to-make-the-beautiful-JavaScript-cod
分享到:
相关推荐
资源名称:编写可靠的JAVAscript代码 测试驱动开发JAVAscript商业软件内容简介:《编写可靠的Javascript代码 测试驱动开发Javascript商业软件》分为5个部分:第Ⅰ部分“奠定坚实的基础”...
在《关于如何编写优美的JavaScript代码之我见》这篇博文中,作者分享了他对编写高质量JavaScript代码的一些见解和实践策略。 首先,源码的质量是关键。一个良好的源码结构能够帮助开发者更好地理解代码的功能和逻辑...
在压缩包中的"很有趣的javascript代码"很可能就是一个或多个这样的外部JS文件,包含了实现特定整人效果的函数和逻辑。这些代码可能包括了时间触发器(如setTimeout或setInterval),用于在特定时间点执行某些操作;...
第Ⅲ部分“测试和编写高级JavaScript特性”描述了如何使用和测试 JavaScript语言更高级的特性。 第Ⅳ部分“测试中的特殊主题”提供了测试DOM操作的样例,还演示了用于增 强代码标准的静态分析工具的使用。第Ⅴ部分...
基于JavaScript实现的程序员表白爱心代码(2套) 基于JavaScript实现的程序员表白爱心代码(2套) 基于JavaScript实现的程序员表白爱心代码(2套) 基于JavaScript实现的程序员表白爱心代码(2套) 基于JavaScript实现的...
JavaScript代码生成器就是一种能够帮助开发者快速生成JavaScript代码的工具,它可以极大提高开发效率,减少手动编写重复性代码的工作量。 JavaScript代码生成器通常具备以下功能: 1. 自动化模板:这些工具提供了...
javascript代码分享,学习js编写教程。 包含各种方法编写技巧
这些构成了编写任何JavaScript代码的基础。 2. **DOM操作**:文档对象模型(DOM)是HTML和XML文档的编程接口。JavaScript通过DOM可以查找、修改和添加页面元素,实现动态更新和交互效果。 3. **事件处理**:...
项目:使用 JavaScript 编写的经典 台球游戏(附源代码) 经典的javascript 台球游戏是一款基于球杆或台球的游戏。整个编程都使用 HTML、CSS 和 JavaScript。这款游戏完全使用 javascript 编写,并使用了一些精灵...
"代码高亮显示JavaScript插件"是专门用于在Web页面中美化和突出显示JavaScript代码的工具,它能够将原始的黑白文本代码转换为具有不同颜色、字体和样式的视觉盛宴。本文将深入探讨这一主题,详细介绍JavaScript代码...
这个示例创建了三个选项,使用 input 元素和 label 元素表示每个选项。在 JavaScript 中,我们通过 document.querySelector 方法获取选中的选项,并将...如果需要处理多个单选投票,需要相应地修改 JavaScript 代码。
"js2c#"工具正是一个旨在帮助开发者将JavaScript代码转换为C#代码的实用工具。这个工具的亮点在于它能够将JS代码编译成DLL或EXE文件,使得C#项目可以直接引用这些编译后的库,从而实现跨语言的代码复用。 首先,...
9. **代码质量与压缩效率**:编写高效的JavaScript代码,减少冗余和不必要的计算,可以提高压缩效果。例如,使用const和let代替var,利用ES6的语法特性,可以提高压缩工具的优化能力。 10. **选择合适的压缩工具**...
用JavaScript编写的一款比较经典的日历代码
1. `test.js`:这很可能是JavaScript测试脚本,用于测试用JavaScript编写的Swing组件。在Rhino环境中运行,它可能包含创建和操作Swing组件的代码,如按钮、文本框、面板等。 2. `src`:这是一个目录,通常包含项目的...
《编写可维护的JavaScript》向开发人员阐述了如何在团队开发中编写具备高可维护性的JavaScript代码,书中详细说明了作为团队一分子,应该怎么写JavaScript。《编写可维护的JavaScript》内容涵盖了编码风格、编程技巧...
代码,书中详细说明了作为团队一分子,应该怎么写JavaScript。《编写可维护的JavaScript》内容涵盖了编码风格、编程技巧、自动化、测 试等几方面,既包括具体风格和原则的介绍,也包括示例和技巧说明,最后还介绍了...
总结一下,服务端运行JavaScript代码的核心在于利用像Node.js这样的平台,使JavaScript突破浏览器限制,在服务器端发挥功能。这种方式不仅简化了全栈开发,还提升了应用性能。随着技术的不断进步,服务端JavaScript...
JS is JS-编写JS独有风格的JS高质量代码 编写JavaScript独有风格的高质量代码 共39页.pptx
内容全部由编写高质量的JavaScript代码的最佳实践组成,从基本语法、应用架构、工具框架、编码风格、编程思想等5大方面对Web前端工程师遇到的疑难问题给出了经验性的解决方案,为Web前端工程师如何编写更高质量的...