Node入门
作者: Manuel Kiessling
翻译: goddyzhao & GrayZhang & MondayChen
原文链接:
关于
本书致力于教会你如何用Node.js来开发应用,过程中会传授你所有所需的“高级”JavaScript知识。
本书绝不是一本“Hello World”的教程。
状态
你正在阅读的已经是本书的最终版。
因此,只有当进行错误更正以及针对新版本Node.js的改动进行对应的修正时,才会进行更新。
本书中的代码案例都在Node.js 0.6.11版本中测试过,可以正确工作。
读者对象
本书最适合与我有相似技术背景的读者:
至少对一门诸如Ruby、Python、PHP或者Java这样面向对象的语言有一定的经验;
对JavaScript处于初学阶段,并且完全是一个Node.js的新手。
这里指的适合对其他编程语言有一定经验的开发者,
意思是说,本书不会对诸如数据类型、变量、控制结构等等之类非常基础的概念作介绍。
要读懂本书,这些基础的概念我都默认你已经会了
。
然而,本书还是会对JavaScript中的函数和对象作详细介绍,
因为它们与其他同类编程语言中的函数和对象有很大的不同。
本书结构
读完本书之后,你将完成一个完整的web应用,该应用允许用户浏览页面以及上传文件。
当然了,应用本身并没有什么了不起的,相比为了实现该功能书写的代码本身,
我们更关注的是如何创建一个框架来对我们应用的不同模块进行干净地剥离。
是不是很玄乎?稍后你就明白了。
本书先从介绍在Node.js环境中进行JavaScript开发和在浏览器环境中进行JavaScript开发的差异开始。
紧接着,会带领大家完成一个最传统的“Hello World”应用,这也是最基础的Node.js应用。
最后,会和大家讨论如何设计一个“真正”完整的应用,剖析要完成该应用需要实现的不同模块,
并一步一步介绍如何来实现这些模块。
可以确保的是,在这过程中,大家会学到JavaScript中一些高级的概念、
如何使用它们以及为什么使用这些概念就可以实现而其他编程语言中同类的概念就无法实现。
该应用所有的源代码都可以通过
本书Github代码仓库().
目录
. 关于
状态
读者对象
本书结构
. JavaScript与Node.js
JavaScript与你
简短申明
服务器端JavaScript
“Hello World”
. 一个完整的基于Node.js的web应用
用例
应用不同模块分析
. 构建应用的模块
一个基础的HTTP服务器
分析HTTP服务器
进行函数传递
函数传递是如何让HTTP服务器工作的
基于事件驱动的回调
服务器是如何处理请求的
服务端的模块放在哪里
如何来进行请求的“路由”
行为驱动执行
路由给真正的请求处理程序
让请求处理程序作出响应
? 不好的实现方式
? 阻塞与非阻塞
? 以非阻塞操作进行请求响应
更有用的场景
? 处理POST请求
? 处理文件上传
. 总结与展望
一、JavaScript与Node.js
1.1 JavaScript与你
抛开技术,我们先来聊聊你以及你和JavaScript的关系。
本章的主要目的是想让你看看,对你而言是否有必要继续阅读后续章节的内容。
如果你和我一样,那么你很早就开始利用HTML进行“开发”,
正因如此,你接触到了这个叫JavaScript有趣的东西,
而对于JavaScript,你只会基本的操作——为web页面添加交互。
而你真正想要的是“干货”,你想要知道如何构建复杂的web站点 —— 于是,
你学习了一种诸如PHP、Ruby、Java这样的编程语言,并开始书写“后端”代码。
与此同时,你还始终关注着JavaScript,随着通过一些对jQuery,Prototype之类技术的介绍,
你慢慢了解到了很多JavaScript中的进阶技能,同
时也感受到了JavaScript绝非仅仅是window.open() 那么简单。
.
不过,这些毕竟都是前端技术,尽管当想要增强页面的时候,使用jQuery总让你觉得很爽,
但到最后,你顶多是个JavaScript用户,而非JavaScript开发者。
然后,出现了Node.js,服务端的JavaScript,这有多酷啊?
于是,你觉得是时候该重新拾起既熟悉又陌生的JavaScript了。
但是别急,写Node.js应用是一件事情;
理解为什么它们要以它们书写的这种方式来书写则意味着——你要懂JavaScript。这次是玩真的了。
问题来了: 由于JavaScript真正意义上以两种,
甚至可以说是三种形态存在(从中世纪90年代的作为对DHTML进行增强的小玩具,
到像jQuery那样严格意义上的前端技术,一直到现在的服务端技术),
因此,很难找到一个“正确”的方式来学习JavaScript,
使得让你书写Node.js应用的时候感觉自己是在真正开发它而不仅仅是使用它。
因为这就是关键: 你本身已经是个有经验的开发者,
你不想通过到处寻找各种解决方案(其中可能还有不正确的)来学习新的技术,
你要确保自己是通过正确的方式来学习这项技术。
当然了,外面不乏很优秀的学习JavaScript的文章。但是,有的时候光靠那些文章是远远不够的。
你需要的是指导。本书的目标就是给你提供指导。
1.2 简短申明
业界有非常优秀的JavaScript程序员。而我并非其中一员。
我就是上一节中描述的那个我。
我熟悉如何开发后端web应用,但是对“真正”的JavaScript以及Node.js,我都只是新手。
我也只是最近学习了一些JavaScript的高级概念,并没有实践经验。
因此,本书并不是一本“从入门到精通”的书,更像是一本“从初级入门到高级入门”的书。
如果成功的话,那么本书就是我当初开始学习Node.js最希望拥有的教程。
1.3 服务端JavaScript
JavaScript最早是运行在浏览器中,
然而浏览器只是提供了一个上下文,它定义了使用JavaScript可以做什么,
但并没有“说”太多关于JavaScript语言本身可以做什么。
事实上,JavaScript是一门“完整”的语言:
它可以使用在不同的上下文中,其能力与其他同类语言相比有过之而无不及。
Node.js事实上就是另外一种上下文,它允许在后端(脱离浏览器环境)运行JavaScript代码。
要实现在后台运行JavaScript代码,代码需要先被解释然后正确的执行。
Node.js的原理正是如此,它使用了Google的V8虚拟机(Google的Chrome浏览器使用的JavaScript执行环境),
来解释和执行JavaScript代码。
除此之外,伴随着Node.js的还有许多有用的模块,它们可以简化很多重复的劳作,比如向终端输出字符串。
因此,Node.js事实上既是一个运行时环境,同时又是一个库。
要使用Node.js,首先需要进行安装。
Win7 下安装 Node.js with socket.io and node-static.
Node.js的安装
1)前往 选择Windows Installer (.msi)版下载;
2)点击安装node-v0.10.31-x86.msi文件(文件名根据版本号命名,安装最新版便是)。
3)测试是否安装成功:
打开cmd窗口,执行node -v,如果显示版本号说明安装成功。
如果提示未找到node命令,则通过cmd窗口定位(cd命令)到安装目录,
再次执行node -v 即可看到版本号了。
如果希望执行命令前不要每次定位到安装目录,
那么请在windows环境变量中添加path路径。
4)安装nodeJS类库。
在cmd中执行以下命令(如果找不到npm命令,处理方法同上)
> npm install express
> npm install yetify
> npm install getconfig
> npm install node-uuid
> npm install socket.io
> npm install node-static
如果执行npm命令提示错误如下:Error:ENOENT,stat'c:\Users\Adminstr.....\npm'
请在该目录下创建npm文件夹,再次执行以上命令。
至此安装宣告成功。
安装完成后,继续回来阅读本书下面的内容。
1.4 “Hello World”
好了,“废话”不多说了,马上开始我们第一个Node.js应用:“Hello World”。
打开你最喜欢的编辑器,创建一个helloworld.js文件。
我们要做就是向STDOUT输出“Hello World”,如下是实现该功能的代码:
console.log("Hello World");
保存该文件,并通过Node.js来执行:
> node helloworld.js
正常的话,就会在终端输出Hello World 。
好吧,我承认这个应用是有点无趣,那么下面我们就来点“干货”。
二、一个完整的基于Node.js的web应用
2.1 用例
我们来把目标设定得简单点,不过也要够实际才行:
. 用户可以通过浏览器使用我们的应用。
. 当用户请求时,可以看到一个欢迎页面,页面上有一个文件上传的表单。
. 用户可以选择一个图片并提交表单,随后文件将被上传到,
该页面完成上传后会把图片显示在页面上。
差不多了,你现在也可以去Google一下,找点东西乱搞一下来完成功能。但是我们现在先不做这个。
更进一步地说,在完成这一目标的过程中,我们不仅仅需要基础的代码而不管代码是否优雅。
我们还要对此进行抽象,来寻找一种适合构建更为复杂的Node.js应用的方式。
2.2 应用不同模块分析
我们来分解一下这个应用,为了实现上文的用例,我们需要实现哪些部分呢?
. 我们需要提供Web页面,因此需要一个HTTP服务器
. 对于不同的请求,根据请求的URL,我们的服务器需要给予不同的响应,
因此我们需要一个路由,用于把请求对应到请求处理程序(request handler)
. 当请求被服务器接收并通过路由传递之后,需要可以对其进行处理,
因此我们需要最终的请求处理程序
. 路由还应该能处理POST数据,并且把数据封装成更友好的格式传递给请求处理入程序,
因此需要请求数据处理功能
. 我们不仅仅要处理URL对应的请求,还要把内容显示出来,
这意味着我们需要一些视图逻辑供请求处理程序使用,以便将内容发送给用户的浏览器
. 最后,用户需要上传图片,所以我们需要上传处理功能来处理这方面的细节
我们先来想想,使用PHP的话我们会怎么构建这个结构。
一般来说我们会用一个Apache HTTP服务器并配上mod_php5模块。
从这个角度看,整个“接收HTTP请求并提供Web页面”的需求根本不需要PHP来处理。
不过对Node.js来说,概念完全不一样了。
使用Node.js时,我们不仅仅在实现一个应用,同时还实现了整个HTTP服务器。
事实上,我们的Web应用以及对应的Web服务器基本上是一样的。
听起来好像有一大堆活要做,但随后我们会逐渐意识到,对Node.js来说这并不是什么麻烦的事。
现在我们就来开始实现之路,先从第一个部分--HTTP服务器着手。
阅读(1784) | 评论(0) | 转发(0) |