`
zengyan2012
  • 浏览: 415407 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

如何编写出优美的JavaScript代码?

    博客分类:
  • web
阅读更多

转自:

http://www.csdn.net/article/2012-12-06/2812544-How-to-make-the-beautiful-JavaScript-cod

 

 

 

1:工具

 

  1. Beautify JavaScript or HTMLhttp://jsbeautifier.org/)可以给你的代码格式化,记得用diff工具对照一下,格式化前后的区别;
  2. SublimeLinter可以动态地在编写时给出JSHint提示(出错行高亮);
  3. Grunt可以在文件变更时给出SHint检验(声音以及桌面通知);

一旦把lint校验做为提交代码的必要过程,排版就会有本质的提高。

2:代码规范

  1. 注释符号‘//’后应该空一格;
  2. 防止变量提升,应先声明后使用(JSHint会提醒出‘_height’存在变量提升以及定义后未使用的错误);
  3. 不应该使用硬编码,并且重复几次(ID后缀名可以定义到常量里,用大写字母);
  4. 不应该有两个配置属性,含义不明(this.opts和this._options);
  5. 若两次以上引用同一对象的属性,应该定义到局部变量再引用(var options = this._options);
  6. 不应该同时使用两种属性命名风格(colModel和table_body);
  7. 局部变量名应该尽可能短,而方法名应该尽可能完整(不应该同时即有fromatTpl又有parseTemplate);
  8. 局部变量名不需要用下划线开头,仅对象私有属性和私有方法有此必要;
  9. 变量名不需要带类型属性(_thdoms叫ths就好);
  10. 使用JavaScript时,for循环基本可以避免(比如jQuery有$.each, $.map,$.filter, $.grep等等高阶函数可用);
  11. jQuery对象名习惯以$开头,以便区分DOM对象;
  12. jQuery查询应尽量使用ontext(如 this.$table = $('table', this.$element) );
  13. jQuery DOM操作和原生DOM操作不应该混用(已经使用jQuery的情况,就应该坚持使用jQuery来操作DOM,避免丑陋的原生操作);
  14. DOM元素构造出来,也不应该再到文档中查询一遍了(图上的构造太复杂,一眼真看不懂);

------------------------------

  • 每个function之间多一空行,是的,除去注释外再多一空行;
  • 适当加空格,比如if和后面的括号之间的空格、小括号和花括号之间的空格、冒号和function之间的空格等等;
  • 风格上保持一致,你的代码里面有的地方+号和运算数之间有空格,有的则没有;
  • 少用下划线开头的变量命名;
  • 一段代码里,var语句可以合并在一起;
  • 暂时不会再修改的function或object,先用编辑器折叠起来,看上去也会整洁很多;
  • 黑色背景的Editor风格不错,不过关键字、注释、运算符等颜色上可以再调整,主要是为了防止审美疲劳,换个色调换个心情;

---------------------------

  1. 代码中逻辑没有分块、没有空行、没有注释、看起来很累,建议对代码进行分块,比如将变量集中在头部定义,然后处理一些赋值,最后执行一些其它的函数。具体到这个例子,有很多不恰当的地方,比如可以先var _height;然后在条件分支中进行赋值,比如在一堆赋值语句中间夹杂了一个parseTemplate。
  2. “_”用得太多,this._var这个可以理解,因为要区分是否私有变量,但是var _height这个完全没有必要加,加得太多反而看着很累,而且也没有任何区分的意义。
  3. 没有将常用的变量缓存,这里最应该缓存的是this._options,要不然看起来很乱,而且缓存起来对性能也是有好处的。
  4. 对象的规划(命名)不清晰,比如this._options和this.opts什么关系?我反正是看不明白。
  5. 代码风格不统一,比如访问对象,之前都是this._options.height,为什么后面出来一个this._options.data['head']?用this._options.data.head不是更清晰么?
  6. 函数内变量名混乱(和第四点很像),比如第二个函数中id和_id什么关系?为什么不用aaaId和bbbId?cre又是什么,难道是createElement缩写?变量尽量起有意义的,可区分的名字。
  7. 函数名称表义不明,命名不符合大部分规范约定。第一眼看到_isHaveTable,我第一反应是,这应该是类似return true或者return false之类的吧。结果一看,这么长,难道返回在后面?又往后看了一眼,这根本就没有返回啊!那为什么要用_isHaveTable啊?_is开头的函数明明白白就应该返回一个true或者false啊。
分享到:
评论

相关推荐

    编写可靠的javascript代码测试驱动开发javascript商业软

    资源名称:编写可靠的JAVAscript代码 测试驱动开发JAVAscript商业软件内容简介:《编写可靠的Javascript代码 测试驱动开发Javascript商业软件》分为5个部分:第Ⅰ部分“奠定坚实的基础”...

    Effective JavaScript 编写高质量JavaScript代码的68个有效方法1

    《Effective JavaScript:编写高质量JavaScript代码的68个有效方法》是David Herman撰写的一本JavaScript编程指南,该书基于作者在Ecma的JavaScript标准化委员会的工作经验,深入探讨了JavaScript的内部工作机制、...

    关于如何编写优美的JavaScript代码之我见

    在《关于如何编写优美的JavaScript代码之我见》这篇博文中,作者分享了他对编写高质量JavaScript代码的一些见解和实践策略。 首先,源码的质量是关键。一个良好的源码结构能够帮助开发者更好地理解代码的功能和逻辑...

    《编写可靠的JAVASCRIPT代码 测试驱动开发JAVASCRIPT商业软件》PDF

    第Ⅲ部分“测试和编写高级JavaScript特性”描述了如何使用和测试 JavaScript语言更高级的特性。 第Ⅳ部分“测试中的特殊主题”提供了测试DOM操作的样例,还演示了用于增 强代码标准的静态分析工具的使用。第Ⅴ部分...

    使用AngularJS编写较为优美的JavaScript代码指南

    **AngularJS 编写优美JavaScript代码指南** 在前端开发领域,AngularJS 是一款非常流行的JavaScript框架,它提供了丰富的功能和工具来构建复杂的应用程序。本文将聚焦于如何使用AngularJS编写更加优雅、易于维护的...

    深入浅出JavaScript源代码

    这些构成了JavaScript语法的基础,是编写任何JavaScript代码的前提。 接着,深入到函数和作用域,这是JavaScript中至关重要的概念。函数可以封装代码,提高可复用性,而作用域则决定了变量的可见性和生命周期。理解...

    编写高质量JavaScript代码的基本要点

    ### 编写高质量JavaScript代码的基本要点 #### 一、引言 在当今互联网技术日新月异的时代背景下,JavaScript作为前端开发的核心语言之一,其重要性不言而喻。随着项目规模不断扩大,代码质量的好坏直接影响着软件...

    javascript经典特效---javascript代码自动生成.rar

    通过学习和运用以上知识点,开发者可以更加高效地编写JavaScript代码,实现各种复杂的特效,并减少重复工作。而“javascript代码自动生成.htm”文件可能提供了关于如何利用这些概念和工具的具体指导,包括实例和教程...

    很有趣的javascript编写的代码

    在压缩包中的"很有趣的javascript代码"很可能就是一个或多个这样的外部JS文件,包含了实现特定整人效果的函数和逻辑。这些代码可能包括了时间触发器(如setTimeout或setInterval),用于在特定时间点执行某些操作;...

    编写可维护的javascript.pdf

    《编写可维护的JavaScript》向开发人员阐述了如何在团队开发中编写具备高可维护性的JavaScript代码,书中详细说明了作为团队一分子,应该怎么写JavaScript。《编写可维护的JavaScript》内容涵盖了编码风格、编程技巧...

    编写可维护的JavaScript,完整扫描版

    代码,书中详细说明了作为团队一分子,应该怎么写JavaScript。《编写可维护的JavaScript》内容涵盖了编码风格、编程技巧、自动化、测 试等几方面,既包括具体风格和原则的介绍,也包括示例和技巧说明,最后还介绍了...

    《编写高质量代码-改善JavaScript程序的188个建议》PDF

    从基本语法、应用架构、工具框架、编码风格、编程思想等5大方面对Web前端工程师遇到的疑难问题给出了经验性的解决方案,为Web前端工程师如何编写更高质量的JavaScript代码提供了188条极为宝贵的建议。对于每一个问题...

    深入浅出javascript源代码

    《深入浅出JavaScript源代码》是一本旨在帮助开发者深入理解JavaScript核心机制的书籍,通过源代码分析来提升对语言本质的理解。这个压缩包包含了这本书籍中的源代码示例,为学习者提供了实际操作和研究的素材。 在...

    用函数式编程技术编写优美的 JavaScript

    ### 使用函数式编程技术编写优美的JavaScript #### 函数式编程概述 函数式编程作为一种编程范式,在学术...通过实践和不断探索,开发者可以逐步掌握这些强大的编程技巧,从而编写出更加优美和高效的JavaScript代码。

    JavaScript代码生成器

    JavaScript代码生成器就是一种能够帮助开发者快速生成JavaScript代码的工具,它可以极大提高开发效率,减少手动编写重复性代码的工作量。 JavaScript代码生成器通常具备以下功能: 1. 自动化模板:这些工具提供了...

    编写高质量代码-改善JavaScript程序的188个建议,完整扫描版

    从基本语法、应用架构、工具框架、编码风格、编程思想等5大方面对web前端工程师遇到的疑难问题给出了经验性的解决方案,为web前端工程师如何编写更高质量的javascript代码提供了188条极为宝贵的建议。对于每一个问题...

    编写可维护的JavaScript

    《编写可维护的JavaScript》向开发人员阐述了如何在团队开发中编写具备高可维护性的JavaScript 代码,书中详细说明了作为团队一分子,应该怎么写JavaScript。《编写可维护的JavaScript》内容涵盖了编码风格、编程...

    Laravel全栈框架:它允许开发者在前端使用PHP编写交互逻辑,无需编写独立的JavaScript代码

    一个用于Laravel的全栈框架,它使构建动态UI变得简单而不...它允许开发者在前端使用PHP编写交互逻辑,无需编写独立的JavaScript代码。对于喜欢Laravel框架的开发者,Livewire提供了一种更加高效的构建动态UI的方式。

    基于JavaScript实现的程序员表白爱心代码(2套)

    基于JavaScript实现的程序员表白爱心代码(2套) 基于JavaScript实现的程序员表白爱心代码(2套) 基于JavaScript实现的程序员表白爱心代码(2套) 基于JavaScript实现的程序员表白爱心代码(2套) 基于JavaScript实现的...

Global site tag (gtag.js) - Google Analytics