写好你的JavaScript

关于

前言

在实际工作中,我们应该经常会看到一些功能上没有问题,但编码风格和规范却十分糟糕的代码,这往往会让人不敢再往下阅读,甚至会影响阅读者一天的心情。这些代码不仅不易阅读,而且难以维护,它们一般会出自刚入门的编程新手,也会出自工作了好几年的老程序员手下。因此本文的目的在于帮助那些没有养成良好的编码风格,缺乏相应编码规范意识的JavaScript学习者们改善他们的编码形象。

编码形象

以上我提出了编码形象的概念,我个人认为:

编码形象 = 编码风格 + 编码规范

一个良好的编码形象就等于一个穿着得体的青年,对于程序员来说这是同行了解你优秀能力的最直接最简单的方式。

我们来看一下一段糟糕的编码形象:

//打个招呼
function func(){
    var age=18,sex=‘man‘;
    var greeting=‘hello‘;
    if(age<=18&&sex==‘man‘){
        console.log(greeting+‘little boy‘)
    }

    ...
}
func()

上方代码整体缩在了一起,缺乏规范意识,阅读体验很差,不忍直视。

再来看一段良好的代码形象:

// 打个招呼
function greetFn() {
    var age = 18,
        sex = ‘man‘,
        greeting = ‘hello‘;

    if (age <= 18 && sex === ‘man‘) {
        console.log(greeting + ‘little boy‘);
    }

    ...
};

greetFn();

上方的代码是不是感觉舒服多了?

由此可见养成一个良好的编码形象是至关重要的,而本文主要讲解的是基于JavaScript的编码形象,即基于JavaScript的编码风格和编码规范。

那么什么是编码风格,什么是编码规范,两者的区别又是什么?

编码风格

首先编码风格既然是风格,就没有对错之分。就好比每个人的穿着打扮不同,有的人穿的比较得体,有的人穿的比较随意而已。

而在JavaScript编码风格中,也有一套比较得体的风格,尤其在团队开发中,我们不能随意的书写属于自己的风格。

下面就列举几种随意的编码风格,并将其与良好的编码风格进行对比。

1.合理注释

// 不推荐的写法
var name = ‘劳卜‘;//代码和注释之间没有间隔

if (name) {
    /*
     *注释之前无空行
     *星号后面无空格
     */
}
// 推荐的写法
var name = ‘劳卜‘; // 代码和注释之间有间隔

if (name) {

    /*
     * 注释之前有空行
     * 星号后面有空格
     */
}

2.合理间隔

// 不推荐的写法
var name=‘劳卜‘; // 等号和两侧之间没有间隔

// if块级语句间没有间隔
if(name){
    console.log(‘hello‘);
}
// 推荐的写法
var name = ‘劳卜‘; // 等号和两侧之间有间隔

// if块级语句间有间隔
if (name) {
    console.log(‘hello‘);
}

3.合理缩进

// 不推荐的写法:没有合理缩进
function getName() {
console.log(‘劳卜‘);
}
// 推荐的写法:合理缩进
function getName() {
    console.log(‘劳卜‘);
}

4.合理空行

// 不推荐的写法: 代码功能块之间没有空行
function getName() {
    var name = ‘劳卜‘;
    if (name) {
        console.log(‘hello‘);
    }
}
// 推荐的写法:代码功能块之间有空行
function getName() {
    var name = ‘劳卜‘;

    if (name) {
        console.log(‘hello‘);
    }
}

5.合理命名

// 不推荐的写法
var getName = ‘劳卜‘; // 变量命名前缀为动词

// 函数命名前缀为名词
function name() {
   console.log(‘hello‘);
}
// 推荐的写法
var name = ‘劳卜‘; // 变量命名前缀为名词

// 函数命名前缀为动词
function getName() {
   console.log(‘hello‘);
}

6.合理声明

// 不推荐的写法:函数在声明之前使用
getName(); 

function getName() {
    console.log(‘hello‘);
}
// 推荐的写法:函数在声明之后使用
function getName() {
    console.log(‘hello‘);
}

getName();

7.合理结尾

// 不推荐的写法:没有使用分号结尾
var name = ‘劳卜‘ 

var getName = function() {
    console.log(‘hello‘)
}
// 推荐的写法:使用分号结尾
var name = ‘劳卜‘; 

var getName = function() {
    console.log(‘hello‘);
};

以上主要列举了7个比较常见的编码风格的例子进行了比较,在推荐的写法和不推荐的写法中两者并没有对错之分,只是推荐的写法相比较而言更容易阅读和维护,更适用于团队开发,也是良好编码形象的体现。

编码规范

对于编码规范,既然是规范,那我们就应该按照一定的规则来编写。随意编写违反编码规范的代码,可能会导致程序的出错和潜在的bug,因此其相对于编码风格来说应该更加严谨,也有人会把编码风格包含在编码规范之中。

下面就列举几个常见的实例代码:

1.比较参数

// 不推荐的写法:==和!=比较时会进行类型转换,应尽量避免使用
var num = 123;

if (num == ‘123‘) {
    console.log(num);
} else if (num != ‘321‘) {
    console.log(‘321‘);
}
// 推荐的写法:使用===和!==来进行比较
var num = 123;

if (num === ‘123‘) {
    console.log(num);
} else if (num !== ‘321‘) {
    console.log(‘321‘);
}

2.包裹if语句

// 不推荐的写法:if语句不用大话号包裹会出现潜在bug
var num = 123;

if (num === ‘123‘)
    console.log(num);
// 推荐的写法:if语句用大话号包裹
var num = 123;

if (num === ‘123‘) {
    console.log(num);
}

3.慎用eval

// 不推荐的写法:应避免使用eval,不安全,非常耗性能(一次解析成js语句,一次执行)
var json = ‘{"name": "劳卜", "func": alert("hello")}‘;

eval(‘(‘ + json + ‘)‘); // 弹出“hello”
// 推荐的写法
var json = ‘{"name": "劳卜", "func": alert("hello")}‘;

JSON.parse(json); // 校验报错

4.判断类型

// 不推荐的写法:用typeof来判断构造函数创建的对象
var str = new String(‘劳卜‘); 

console.log(typeof str); // ‘object‘
// 推荐的写法:用instanceof来判断构造函数创建的对象
var str = new String(‘劳卜‘); 

console.log(str instanceof String); // true

5.检测属性

// 不推荐的写法:使用undefined和null来检测一个属性是否存在
if (obj[‘name‘] !== undefined) {
    console.log(‘name属性存在‘); // 若obj.name为undefined时则会导致判断出错
}

if (obj[‘name‘] !== null) {
    console.log(‘name属性存在‘); // 若obj.name为null时则会导致判断出错
}
// 推荐的写法:使用in运算符来检测对象属性是否存在,使用hasOwnProperty方法来检测不包含原型链上的对象属性是否存在
if (‘name‘ in obj) {
    console.log(‘name属性存在‘);
}

if (obj.hasOwnProperty(‘name‘)) {
    console.log(‘name属性存在‘);
}

以上主要列举了5个常见的编码规范的例子,合理地规范自己的代码能够很大程度上减少不必要的维护成本和潜在的bug风险,对于JavaScript学习者来说应该铭记于心。

结语

“程序是写给人读的,只是偶尔让计算机执行一下。”我们不能为了贪图一时的方便而亲手毁了自己的代码形象,这会给他人和整个项目带来不必要的麻烦。

本文内容参考自《编写可维护的JavaScript》一书。

?

时间: 2024-10-07 05:27:02

写好你的JavaScript的相关文章

用6个字符写出任意的Javascript代码

博客搬到了fresky.github.io - Dawei XU,请各位看官挪步.最新的一篇是:用6个字符写出任意的Javascript代码.

写的一个轻量级javascript框架的设计模式

公司一直使用jQuery框架,一些小的项目还是觉得jQuery框架太过于强大了,于是自己周末有空琢磨着写个自己的框架.谈到js的设计模式,不得不说说js的类继承机制,javascript不同于PHP可以轻松的实现类继承,不过javascript的类继承方法还是有的,常见的有构建函数.原型扩展.综合……,也有一些专门写类的函数,例如jQuery的作者有个类继承函数.关于类继承写法可以简单看 ______________________________________________________

自己的写的HTML5 Canvas + Javascript五子棋

看到一些曾经只会灌水的网友,在学习了前端之后,已经能写出下载量几千几万的脚本.样式,帮助大众,成为受欢迎的人,感觉满羡慕的.我也想学会前端技术,变得受欢迎呀.于是心血来潮,开始学习前端知识,并写下了这个小练习. 基本思路是这样的: 使用Canvas绘制棋盘.棋子. 用二维数组保存棋盘状态. 设置一个flag,用以标识落子顺序. 点击时,在数组中检测当前点击位置是否存在棋子,若存在,则不落子:如游戏已结束,亦不落子. 落子时,更新数组,并将当前落子所在的行.列.左上-右下列.左下-右上列四个方向的

如何写出规范的JavaScript代码

作为一名开发人员(WEB前端JavaScript开发),不规范的开发不仅使日后代码维护变的困难,同时也不利于团队的合作,通常还会带来代码安全以及执行效率上的问题.本人在开发工作中就曾与不按规范来开发的同事合作过,与他合作就不能用"愉快"来形容了.现在本人撰写此文的目的除了与大家分享一点点经验外,更多的是希望对未来的合作伙伴能够起到一定的借鉴作用.当然,如果我说的有不科学的地方还希望各路前辈多多指教.下面分条目列出各种规范要求,这些要求都是针对同事编码毛病提出来的,好些行业约定的其它规范

自己写的HTML5 Canvas + Javascript五子棋

看到一些曾经只会灌水的网友,在学习了前端之后,已经能写出下载量几千几万的脚本.样式,帮助大众,成为受欢迎的人,感觉满羡慕的.我也想学会前端技术,变得受欢迎呀.于是心血来潮,开始学习前端知识,并写下了这个小练习. 基本思路是这样的: 使用Canvas绘制棋盘.棋子. 用二维数组保存棋盘状态. 设置一个flag,用以标识落子顺序. 点击时,在数组中检测当前点击位置是否存在棋子,若存在,则不落子:如游戏已结束,亦不落子. 落子时,更新数组,并将当前落子所在的行.列.左上-右下列.左下-右上列四个方向的

用正则表达式写trim函数(javascript)

function trim(str){ return str.replace(/(^\s*)|(\s*$)/g, "");//删除左右两端的空格 } function ltrim(str){ return str.replace(/(^\s*)/g,"");//删除左边的空格 } function rtrim(str){ return str.replace(/(\s*$)/g,""); //删除右边的空格 } 测试 function trim(

自写小函数处理 javascript 0.3*0.2 浮点类型相乘问题

const reg = /^([0-9]+)\.([0-9]*)$/; // 判断是不是浮点数 const isFloat = function(number){ return reg.test(number); } // 去除小数点转为整数 const floatToInt = function(head,tail){//head:String tail:String // head和tail都是字符串 Number("005")可以去零 let result = head + Nu

作业:JavaScript(数组篇-poker)给我的徒弟出个题。。。记得早点写完,然后大家3人可以早点打牌了

吐槽一下:“今天实际上我左思右想,写个什么东西好呢!手上的笔转了半天....最后还是给自己留点余地!看着他们什么酒店管理系统,呼叫中心系统之类的....简直是把自己固定死了!感觉一撸到底的感觉!!!我们是程序员所以我觉得要思想灵活点HOHO...” 今天只是想写一篇关于JavaScript数组的一篇文章 以前我认为我已经完全把数组掌握了!但是去年面试的时候被问呆了!!瞬间感觉自己萌萌哒!!所以把书看完了不算会!所以这次为了让我的徒弟能够不再犯我当年的错误...哼哼!我决定让她来一次实战!!!不能

只用这 6 个字符,就可以写出任意 JavaScript 代码!

你可能在网上见过有人用 几个不同的字符写的各种稀奇古怪的 JavaScript 代码,虽然看起来奇怪,但是能正常运行!比如这个: (!(~+[])+{})[--[~+""][+[]]*[~+[]] + ~~!+[]]+({}+[])[[~!+[]]*~+[]] 复制代码 你猜运行结果是什么?你可以自己去控制台试一下. 看起来很神奇,但这到底是怎么回事呢? 事实上,你几乎可以用下面这 6 个字符写出任意的 JavaScript 程序: []()!+ 复制代码 很多人都知道这个技巧,但是没