`

javascript的编程风格--Crockford代码规范

 
阅读更多

下面即使Crockford编写的"代码规范"的总结:

规则1:表示区块起首的大括号,不要另起一行。

例如:

return

  {

    key:value;

  };

  上面的代码的原意,是要返回一个对象,但实际上返回的是undefined,因为Javascript自动在return语句后面添加了分号。为了避免这一类错误,需要写成下面这样:

  return {

    key : value;

  };

  规则2:调用函数的时候,函数名与左括号之间没有空格。

  规则3:函数名与参数序列之间,没有空格。

  规则4:所有其他语法元素与左括号之间,都有一个空格。

    规则5:不要省略句末的分号。

     分号表示语句的结束。大多数情况下,如果你省略了句尾的分号,Javascript会自动添加。但是

下一行的第一个字元(token)是下面这五个字符之一,Javascript将不对上一行句尾添加分号:"("、"["、"/"、"+"和"-"。

     规则6:不要使用with语句。

    with可以减少代码的书写,但是会造成混淆。

例如:

with(o){

foo=xxx;

}//会出现很多种变量赋值的含义。

   规则7:不要使用"相等"(==)运算符,只使用"严格相等"(===)运算符。

例如:

  0 == ''// true

  1 == true // true

  2 == true // false

  0 == '0' // true

  false == 'false' // false

     规则8:不要将不同目的的语句,合并成一行。

例如:

a = b;

  if (a) {...}

  他喜欢写成下面这样:

  if (a = b) {...}

  虽然语句少了一行,但是可读性大打折扣,而且会造成误读。

     规则9:所有变量声明都放在函数的头部。

  规则10:所有函数都在使用之前定义。

例如:

 if (!o) {

    var o = {};

  }

  等同于

  var o;

  if (!o) {

    o = {};

  }

  为了避免可能出现的问题,不如把变量声明都放在代码块的头部。

  for (var i ...) {...}

  最好写成:

  var i;
  for (i ...) {...,}

      规则11:避免使用全局变量;如果不得不使用,用大写字母表示变量名。

   因为javascript最大缺点是全局变量对于所有的函数块都是可读可写的。,这对于代码的模块化和重复使用非常不利。

     规则12:不要使用new命令(构建对象关键词),改用Object.create()命令。

     规则13:建构函数的函数名,采用首字母大写(InitialCap);其他函数名,一律首字母小写。

    例如:

 Javascript使用new命令,从建构函数生成一个新对象。

  var o = new myObject();

  这种做法的问题是,一旦你忘了加上new,myObject()内部的this关键字就会指向全局对象,导致所有绑定在this上面的变量,都变成全部变量。

   规则14:不要使用自增(++)和自减(--)运算符,用+=和-=代替。

     规则15:总是使用大括号表示区块。

   虽然循环和判断的代码体只有一行,Javascript允许该区块(block)省略大括号。但是这样有事由于初心带来不必要的麻烦。

 

 

 

分享到:
评论

相关推荐

    浅谈Javascript编程风格

    本文将基于Douglas Crockford的演讲和其编写的代码规范,探讨JavaScript编程风格的一些关键点。 首先,关于大括号({})的位置。在JavaScript中,大括号用于表示代码块,常见的有两种风格:一种是大括号另起一行,...

    JavaScript编程风格

    JavaScript编程风格是编程实践中的一种规范,旨在提高代码的可读性、可维护性和减少错误。以下是一些由JavaScript权威Douglas Crockford提出的编程风格建议: 1. **大括号的位置**: - 在JavaScript中,为了防止因...

    JavaScript:The Good Parts May

    10. **最佳实践**:Crockford提出了许多JavaScript编程的最佳实践,如避免使用with语句、尽量减少全局变量的使用,以及如何有效地组织和模块化代码。 通过阅读《JavaScript:The Good Parts May》,Web开发者不仅...

    EditPlus的JSLint插件(检验Javascript编写规范)

    **EditPlus的JSLint插件与JavaScript编程规范** 在编程世界中,代码规范和一致性至关重要,它们可以提高代码质量,提升团队合作效率,并降低维护成本。JavaScript作为一门广泛使用的脚本语言,也不例外。JSLint是一...

    javascript源码检测工具

    3. **代码风格**:JSLint推崇Crockford的JavaScript编程风格,比如强制使用特定的缩进方式、限制行长度、禁止使用特定的函数或语句(如with语句)等。 4. **类型检查**:JSLint会检查变量和表达式的类型,防止因...

    JavaScript the good parts

    Crockford提倡的是一种更为纯净的JavaScript编程实践,让开发者能够写出更高效、更稳定的代码,尤其在处理对象库和Ajax应用时。 这本书不仅适合初学者,也适合有经验的JavaScript开发者,它提醒我们,即使在一门...

    JavaScript语言精粹 (英文版)

    - **优美的特性**:列举并解释JavaScript中的一些优秀特性,如简洁的代码风格、动态特性等。 #### 四、书籍价值 1. **提高代码质量**:通过学习本书提出的JavaScript子集,开发者可以避免一些常见的错误和陷阱,...

    ECMAScriptBestPractices:基于道格拉斯·克罗克福德(Douglas Crockford)的Javascript YUI系列的ECMAScript中的良好实践的实现

    - 遵守一定的代码格式规范,如JSDoc、Airbnb风格指南或Google风格指南。 - 使用ESLint等静态代码分析工具检查代码质量。 9. **性能优化**: - 了解V8引擎的特性,编写高效的JavaScript代码。 - 避免DOM操作的...

    jsLint JAVASCRIPT静态检查工具

    本文将详细介绍`jsLint`及其在JavaScript编程中的应用。 `jsLint`是由Douglas Crockford创建的一款开源工具,其主要目的是帮助开发者找出代码中的潜在错误、不规范的语法和风格问题,提升代码质量。`jsLint`通过对...

    jslint的javascript语法检测

    JavaScript是Web开发中不可或缺的一部分,而`jslint`是一个用于检查JavaScript代码质量的工具,它可以帮助开发者找出潜在的语法错误、不规范的编程习惯以及可能的性能问题。本篇文章将深入探讨`jslint`及其在...

    JSLint Plugin for Notepad++

    JSLint 是一款由JavaScript之父道格拉斯·克罗克福德(Douglas Crockford)开发的代码质量工具,它主要用于检查JavaScript代码中的语法错误,并提供编程风格和最佳实践的建议。这个强大的工具可以帮助开发者编写更...

Global site tag (gtag.js) - Google Analytics