网络埋伏纪事

Node Hero - 1. 开始使用 Node.js

网络埋伏纪事 · 2016-11-21翻译 · 1282阅读 原文链接

这是 Node.js 系列教程 Node Hero 的第一篇文章。在这些章节中,将学习如何上手 Node.js 以及如何使用它交付软件产品。

本教程从基础开始 - 不需要以前有 Node.js 知识。本教程的目标是让你入门 Node.js,确保你可以理解如何用它来编写应用程序,所以如果有不清楚的,请马上问我们。

目录

  1. 开始使用 Node.js
  2. 使用 NPM
  3. 理解异步编程
  4. 第一个 Node.js 服务器
  5. Node.js 数据库教程
  6. Node.js request 模块教程
  7. Node.js 项目结构教程
  8. Node.js 身份验证 - 使用 Passport.js
  9. Node.js 单元测试教程
  10. 调试 Node.js 应用程序
  11. Node.js 安全教程
  12. 如何部署 Node.js 应用程序
  13. 监控 Node.js 应用程序

在第一篇教程中,将学习什么是 Node.js,如何在电脑上安装它,如何开始使用它 - 这样在下一章我们就可以做实际开发。我们开始吧!

Node.js 概述

node.js logo in node hero getting started tutorial

官方 Node.js logo

Node.js 是一个建立在 Chrome 的 JavaScript 引擎 V8 之上的 JavaScript 运行时。Node.js 使用一个事件驱动的非阻塞式的 I/O 模型,让它轻量而高效。

也就是说:Node.js 提供了用 JavaScript 编写服务器的可能性,这种服务器具有令人难以置信的性能。正如官方声明所说:Node.js 是一个使用与 Google Chrome 浏览器相同 JavaScript 引擎 V8 的运行时。但是这还不足以支撑 Node.js 的成功 - Node.js 还使用了专注于异步 I/O 的多平台支持库 libuv

libuv logo in node hero getting started tutorial

官方 libuv logo

从开发者的观点来看,NodeJS 是单线程的 - 但是在幕后,它是用 libuv 来处理线程、文件系统事件、实现事件循环、使 Node.js 具有线程池特征 等等。大多数情况下,我们不会直接与它交互。

安装 Node.js

要得到最新的 Node.js 执行文件,可以访问 Node.js 官网:https://nodejs.org/en/download/

用这种方法,很容易开始 - 但是如果以后要添加更多 Node.js 版本,最好是从使用 Node 的版本管理器 nvm 开始。

一旦安装了 NVM,就可以使用很简单的 CLI API 来与 Node.js 交互了。

安装 Node.js 版本

nvm install 4.4

然后,如果想看看试验性版本:

nvm install 5

要校验 Node.js 的启动和运行,请执行:

node --version

如果一切顺利,就会返回当前活动的 Node.js 执行文件的版本号。

使用 Node.js 版本

如果正在开发一个支持 Node.js v4 的项目,可以用如下命令开始使用它:

nvm use 4

然后可以用如下命令切换到 Node.js v5:

nvm use 5

好了,现在我们知道了如何安装和在 Node.js 版本之间切换 - 但是这有何意义?

自从 Node.js 基金会成立,Node.js 就有一个发布计划。这与 Linux 基金会的其它项目很相似。这意味着有两个发布版本:稳定版和试验版。在 Node.js 中,带有长期支持(LTS)的稳定版是以偶数开始(4,6,8...),而试验版是从奇数开始(5, 7...)。我们推荐在生产环境中用 LTS 版本,而用试验版尝试新东西。

如果你的操作系统是 Windows,请使用 nvm-windows

Hello World

要开始使用 Node.js,先在终端中试试!只需要键入 node,就可以启动 Node.js:

$ node
>

好了,下面我们试着打印点什么:

$ node
> console.log('hello from Node.js')

一旦敲了回车,就会得到下面这样的信息:

> console.log('hello from Node.js')
hello from Node.js  
undefined

用这个界面随便玩玩 Node.js - 通常会在这里尝试点小代码片段,因为我不想把它们放到一个文件中。


是时候创建我们的 Hello Node.js 应用了!

首先创建一个 index.js 文件。打开 IDE(Atom、Sublime、Code 都行),创建一个新文件,然后存为 index.js。完成后,复制如下代码片段到该文件中:

// index.js
console.log('hello from Node.js')

要运行该文件,只需再次打开终端,转到你存放 index.js 文件的目录,然后执行 node index.js 命令。你会看到它会生成与前面一样的输出 - 在终端上直接打印字符串。

模块化你的应用程序

现在你已经有了 index.js 文件,该升级一下游戏了!下面我们创建更复杂的应用,基于可读性和可维护性的目的,将源代码分成多个 JavaScript 文件。打开 IDE(Atom、Sublime、Code 都可以),创建如下目录结构(带有空文件),但是暂时忽略 package.json,我们将在下一步自动生成它:

├── app
|   ├── calc.js
|   └── index.js
├── index.js
└── package.json

每个 Node.js 项目都是从创建一个 package.json 文件开始 - 可以把它当作是应用程序及其依赖的 JSON 表示。它包含了应用程序的名称、作者,以及运行应用程序所需的所有依赖。我们打算在后面使用 NPM 一章中再讲解依赖。

可以在终端中使用 npm init 命令,以交互式的方式生成 package.json 文件。

键入回车后,会被要求给几个输入,比如应用程序的名称、版本、描述等等。不要担心,只管敲回车,直到得到了 JSON 片段,以及提问 is it ok?。最后一次敲回车,package.json 就被自动生成了,放在应用程序的文件夹中。如果在 IDE 中打开该文件,就会看到跟如下代码片段很相似的代码:

{
  "name": "@risingstack/node-hero",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1",
    "start": "node index.js"
  },
  "author": "",
  "license": "ISC"
}

package.json 添加一个 start 脚本是一个好实践 - 一旦你像上例一样这样做了,就可以用 npm start 启动应用。如果要把应用程序部署给 PaaS 提供者,那么就很方便了 - 它们会识别它,然后用它启动你的应用程序。

现在回到我们创建的第一个文件 index.js。我建议让这个文件保持很瘦 - 只请求应用程序本身(来自你之前创建的 /app 子目录下的 index.js 文件)。复制如下脚本到 index.js 文件,然后存盘:

// index.js
require('./app/index')

现在到了开始创建实际应用程序的时候了。打开 /app 文件夹下的 index.js 文件,创建一个很简单的示例:数字数组相加。在本例中,index.js 会只包含我们要加的数字,执行计算的逻辑需要放在另一个模块中。

将如下脚本粘贴到 /app 目录下的 index.js 中。

// app/index.js
const calc = require('./calc')

const numbersToAdd = [  
  3,
  4,
  10,
  2
]

const result = calc.sum(numbersToAdd)  
console.log(The result is: ${result})

现在将实际的业务逻辑粘贴到同一文件夹下的 calc.js 文件中。

// app/calc.js
function sum (arr) {  
  return arr.reduce(function(a, b) { 
    return a + b
  }, 0)
}

module.exports.sum = sum

要检查你是否成功,就保存这些文件,打开终端,键入 npm start 或者 node index.js。如果你所有东西都做对了,会得到答案:19。如果出错了,就仔细检查一下控制台日志,根据日志找到问题所在。

接下来

在下一章使用 NPM 中,我们会看看如何使用 JavaScript 的包管理器 NPM。

相关文章