[译]Node.js Best Practices
原文: http://blog.risingstack.com/node-js-best-practices/
下面的的最佳实践分为代码风格和开发工作流两种.
代码风格
Callback约定
Modules应该暴露出一个以error为第一个参数的callback接口.
如下:
module.exports = function (dragonName, callback) {
// 写下你module的逻辑
var dragon = createDragon(dragonName); // 注意, 第一个参数是error
// 在这里error为null
// 但是当一个错误发生的时候应该是一个Error
return callback(null, dragon);
}
总是在callback函数里面去检查error
为了更好的理解为什么要在callback函数里面检查error, 我们故意让程序出错, 下一步在修复他.
// this example is **BROKEN**, we will fix it soon :)
var fs = require('fs'); function readJSON(filePath, callback) {
fs.readFile(filePath, function(err, data) {
callback(JSON.parse(data));
});
} readJSON('./package.json', function (err, pkg) { ... }
readJSON的第一个问题是他从来没有去检查是否出错.下面让我们来改善一下
// this example is **STILL BROKEN**, we are fixing it!
function readJSON(filePath, callback) {
fs.readFile(filePath, function(err, data) {
// 在这我们检查是不是有一个错误发生了
if (err) {
// 传递error给callback
// 记住: callback的第一个参数是err
callback(err);
} // 没错的话, 传递一个null和JSON
callback(null, JSON.parse(data));
});
}
返回callback
上面的例子还有一个错误, 如果一个错误发生了, 代码不会在if里面停止还会继续执行下面的代码. 我们一定要记得return callback.
// this example is **STILL BROKEN**, we are fixing it!
function readJSON(filePath, callback) {
fs.readFile(filePath, function(err, data) {
if (err) {
return callback(err);
} return callback(null, JSON.parse(data));
});
}
在同步代码里面使用try-catch
值得注意的是如果传入的data是一个非法的JSON格式, JSON.parse可能会抛出一个
exception.
因为JSON.parse是同步执行的
, 我们可以用一个try-catch把他包起来. 注意, 只能在同步的代码块用try-catch!
// this example **WORKS**! :)
function readJSON(filePath, callback) {
fs.readFile(filePath, function(err, data) {
var parsedJson; // Handle error
if (err) {
return callback(err);
} // Parse JSON
try {
parsedJson = JSON.parse(data);
} catch (exception) {
return callback(exception);
} // Everything is ok
return callback(null, parsedJson);
});
}
避免使用avoid和new
在Node里面绑定一个特殊的上下文不是一个好的选择, 因为Node有太多太多的callback, and heavy use of higher-level functions to manage control flow. 使用函数风格可以解决你很多问题.
当然在某些情况下使用prototypes非常有效率, 但是如果可以的话尽量避免使用他们.
创建小的modules
使用好的异步模式
使用 async.
处理Error
Errors分为两种: operational errors 和 programmer errors.
Operational errors
及时完美无bug的应用也可能发生错误, 如下:
- 请求超时
- 系统内存耗尽
- 链接远程服务失败failed to connect to a remote service
处理operational errors
你可以通过下面的方式来处理:
- 试着去解决错误 - 如果一个文件没了, 你可以先创建一个
- 诸如请求外网失败的时候可以自动重新在去操作一次
- 告诉客户有错误发生了 - 可以使用来处理客户的输入
- Crash the process, when the error condition is unlikely to change on its own, like the application cannot read its configuration file
当然最重要的是使用log.
Programmer errors
Programmer errors一般来说都是一些bug, 如下:
- 调用异步函数但是没有使用callback
不能读取undefined的属性
处理programmer errors
立刻崩溃 - 因为这些错误是一些bug. 当应用崩溃的话, 应该自动去重新启动应用. 可以使用: supervisord 和 monit.
Workflow tips
开始一个新项目的第一步一定是npm init
init
命令帮助我们创建应用程序的package.json
文件.
以下面的命令开始你的新项目:
mkdir my-awesome-new-project
cd my-awesome-new-project
npm init
指定一个start和test script
在package.json中的
scripts节点中里面设置script
. 默认情况下面npm生成两个script, start
和test
. 在这我们可以使用npm start和
npm test
.
我们可以自定义一些script, 可以使用npm run-script <SCRIPT_NAME> 调用触发
.
Note, that NPM will set up $PATH
to look in node_modules/.bin
for executables. This helps avoid global installs of NPM modules.
环境变量
Production/staging 部署应该通过环境变量来完成.
可以使用nconf根据你的环境变量, 加载不同的配置.
不要重复制造轮子
总是先查找是不是已经有现成的解决方案. NPM有非常多的packages, 这里极有可能有符合你要求的package.
使用统一的代码风格指南
如果代码都是使用一种风格编写的, 这将对我们阅读代码变的容易些. 比如缩进规则, 参数命名规则.
可以看看这 RisingStack's Node.js style guide.
[译]Node.js Best Practices的更多相关文章
- [译]Node.js Best Practices - Part 2
原文: https://blog.risingstack.com/node-js-best-practices-part-2/ 统一风格 在大团队开发JS应用, 创建一个风格指南是很有必要的. 推荐看 ...
- [译]Node.js - Event Loop
介绍 在读这篇博客之前,我强列建议先阅读我的前两篇文章: Getting Started With Node.js Node.js - Modules 在这篇文章中,我们将学习 Node.js 中的事 ...
- [译]Node.js Interview Questions and Answers (2017 Edition)
原文 Node.js Interview Questions for 2017 什么是error-first callback? 如何避免无止境的callback? 什么是Promises? 用什么工 ...
- 译\Node.js应用的持续部署
Node.js应用的持续部署 翻译前 翻译自:https://blog.risingstack.com/continuous-deployment-of-node-js-applications/ 正 ...
- [译]Node.js : Building RESTful APIs using Loopback and MySQL
国庆后可能就要使用StrongLoop那套东西来做项目了 原文:http://www.javabeat.net/loopback-mysql/ Loopback是什么? Loopback是一个开源的N ...
- [译]Node.js面试问与答
原文: http://blog.risingstack.com/node-js-interview-questions/ 什么是error-first callback? 如何避免无休止的callba ...
- (译)Node.js的 EventEmitter 教程
原文标题:Node.js EventEmitter Tutorial 原文链接:http://www.hacksparrow.com/node-js-eventemitter-tutorial.htm ...
- (译)Node.js的全局变量
原文标题:Global Variables in Node.js 原文链接:http://www.hacksparrow.com/global-variables-in-node-js.html 你可 ...
- (译)Node.js的模块-exports和module.exports
原文标题:Node.js Module – exports vs module.exports 原文链接:http://www.hacksparrow.com/node-js-exports-vs-m ...
随机推荐
- dedecms /member/uploads_edit.php SQL Injection Vul
catalog . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述 Dedecms 5.3版本下的member/uploads_edit.p ...
- XmlReader读取XML
StringBuilder output = new StringBuilder(); String xmlString = @"<bookstore> <book gen ...
- 第二次作业———“A+B Format”思路与总结
GitHub链接: https://github.com/zzy19961112/object-oriented "A+B Format" 题目 解题思路: 一开始粗略看这道题,熟 ...
- python json.dumps() json.dump()的区别
以前写的很简单,只有几句话,最近发现本文是本博客阅读量最大的一篇文章,觉得这样有种把人骗进来的感觉,于是又细化了一些.如果还有不好的地方,欢迎指出. 首先说明基本功能: dumps是将dict转化成s ...
- chmod权限设置
一.其语法格式为:chmod [who] [opt] [mode] 文件/目录名 1.其中who表示对象,是以下字母中的一个或组合: u:表示文件所有者 g:表示同组用户 o:表示其它用户 a:表示所 ...
- OpenGLES入门笔记二
#import <UIKit/UIKit.h> #import <QuartzCore/QuartzCore.h> #import <OpenGLES/ES2/gl.h& ...
- 算法与设计模式系列1之Python实现常见算法
preface 常见的算法包括: 递归算法 二分法查找算法 冒泡算法 插入排序 快速排序 二叉树排序 下面就开始挨个挨个的说说原理,然后用Python去实现: 递归算法 一个函数(或者程序)直接或者间 ...
- UVA11624Fire!(BFS)
题目链接 题意:帮助joe走出一个大火蔓延的迷宫,其中joe每分钟可往上下左右四个方向之一走,所有着火的格子都会蔓延(空格与着火格有公共边,下一分钟这个空格也会着火).迷宫中有一些障碍格,joe和火都 ...
- Java——其他容器
除了JFrame表示之外,还有其他几种常见的窗体:JPanel.JSplitPane.JTabbedPane.JScrollPane.JDesktopPane.JInternalFrame等. imp ...
- MySQL学习笔记——约束
1.约束是在表上强制执行的数据检验规则,约束主要用于保证数据库的完整性. 2.当表中数据有相互依赖性时,可以保护相关的数据不被删除. 3.大部分数据库支持下面五类完整性约束: - NOT NULL非空 ...