了不起的node.js读书笔记之node.js中的特性


Posted in Javascript onDecember 22, 2014

环境的变化带来了技术大跃进,机遇和挑战同时到来。基于我js也没有学,只好赶鸭子上架一起学了。(>?<)

了不起的node.js读书笔记之node.js中的特性

1.先读读书

一开始就不知死活地看《深入浅出node.js》,弄得团团转,看完才知道这本书是要一定基础的。在网上搜刮到了41页的《node入门》,自己学着搭建了一个Web应用。并且在刷新成就感后,就抱读《了不起的node.js》。现准备看完这本书后再回读《深入浅出node.js》。

2.搭建环境 运行git上的例程(3次报错)

在官网下载msi后,一路next。输入命令npm install时,报错"npm ERR! not found: git"。原因是新电脑没有按照git。

安装外部依赖包时,报错"gyp ERR! configure error",原因也是Python环境没有。而且这个依赖包只能在低版本下安装。最后一次报错是"MSBUILD:error MSB3428:未能加载Visual C++组件"VCBuild.exe"",在安装.net framework 2.0 SDK和mvs2005后还是报错。果断弃了。

3.第一个Web应用

在运行完"Hello World"后,开始编写一个完全基于Node的Web应用。首先需要启动服务器模块,http模块中的createServer函数返回的对象有一个listen([PORT])方法监听端口。这个函数的参数很奇怪,是一个函数定义。在JavaScript中,一个函数可以作为另一个函数接收一个参数,参数函数就叫匿名函数。而使用这种方法的原因是node采用了基于事件驱动的回调。当服务器在单进程接收到一个请求时,就会调用这个函数来处理这个请求。当有相应的事件发生时,createServer函数就调用这个函数来回调。

了不起的node.js读书笔记之node.js中的特性

在完成接收http请求后,我们就要处理请求了。首先,我们抽象地把请求提出不同的URL和GET、POST参数。这里用到了两个内部模块URL(解析URL)、Query String(处理查询字符串)。并且通过依赖注入的方式把router模块添加进去。接着,需要完成处理请求的模块,才完善路由。请求先全部通过一个对象(handle)进行模块间的传递,并让处理程序能做出响应。一般来说,让请求处理程序通过onRequest函数直接返回(return())他们要展示给用户的信息。不过,在进行阻塞操作时会非常耗时,所以我们要使用非阻塞操作。使用回调,通过将函数作为参数传递给其他需要花时间做处理的函数。相比采用将内容传递给服务器的方式,我们这次采用将服务器“传递”给内容的方式。就是将response对象(从服务器的回调函数onRequest()获取)作为函数参数通过路由传递给处理程序。这样,处理程序就可以调用该对象上的函数。

接下来再进行处理环节,通过表单来上传图片,这里用到了外部依赖包formidable来接收图片。这个模块就是用来处理表单和上传文件的。首先使用var form = new formidable.IncomingForm();来获得一个表单对象。这个对象的parse方法可以解析处理表单数据。我们就很简单地把文件保存起来。而保存文件则使用了fs模块。通过重命名方法来指定保存的位置,通过使用同步的方法renameSync()可以使得保存文件行为先于展示图片行为。

展示图片则十分简单,通过fs的readFile方法读取文件,在其回调函数中使用response.write(file, "binary")就可以在浏览器中展示图片。

总结一下:通过这个例程,我们了解到了node.js中的特性,如单线程、异步、事件驱动等。其中一些抽象概念也通过例程展示了一遍,但还需深入了解。通过例程学习就是需要在不懂时查阅资料,这种学习方法也是很好的Input-Person-Output型的方法。

Javascript 相关文章推荐
javascript控制frame,iframe的src属性代码
Dec 31 Javascript
js判读浏览器是否支持html5的canvas的代码
Nov 18 Javascript
fixedBox固定div漂浮代码支持ie6以上大部分主流浏览器
Jun 26 Javascript
jQuery+slidereveal实现的面板滑动侧边展出效果
Mar 14 Javascript
JS实现弹性漂浮效果的广告代码
Sep 02 Javascript
js判断当前页面在移动设备还是在PC端中打开
Jan 06 Javascript
JavaScript判断图片是否已经加载完毕的方法汇总
Feb 05 Javascript
Javascript中this绑定的3种方法与比较
Oct 13 Javascript
JavaScript基础进阶之数组方法总结(推荐)
Sep 04 Javascript
Vue from-validate 表单验证的示例代码
Sep 26 Javascript
推荐10款扩展Web表单的JS插件
Dec 25 Javascript
vue引入ueditor及node后台配置详解
Jan 03 Javascript
jQuery+ajax中getJSON() 用法实例
Dec 22 #Javascript
IE8中动态创建script标签onload无效的解决方法
Dec 22 #Javascript
javascript的日期对象、数组对象、二维数组使用说明
Dec 22 #Javascript
javascript中的遍历for in 以及with的用法
Dec 22 #Javascript
Jquery实现图片预加载与延时加载的方法
Dec 22 #Javascript
javascript定义变量时加var与不加var的区别
Dec 22 #Javascript
javascript操作字符串的原生方法
Dec 22 #Javascript
You might like
Laravel5框架添加自定义辅助函数的方法
2018/08/01 PHP
PHP实现的微信APP支付功能示例【基于TP5框架】
2019/09/16 PHP
node.js操作mongodb简单示例分享
2017/05/25 Javascript
JavaScript正则表达式和级联效果
2017/09/14 Javascript
解决vue动态为数据添加新属性遇到的问题
2018/09/18 Javascript
JavaScript设计模式之享元模式实例详解
2019/01/17 Javascript
详解mpvue开发微信小程序基础知识
2019/09/23 Javascript
javascript网页随机点名实现过程解析
2019/10/15 Javascript
vuex存值与取值的实例
2019/11/06 Javascript
nodejs各种姿势断点调试的方法
2020/06/18 NodeJs
JavaScript实现动态生成表格
2020/08/02 Javascript
vue 解决mintui弹窗弹起来,底部页面滚动bug问题
2020/11/12 Javascript
JavaScript中展开运算符及应用的实例代码
2021/01/14 Javascript
Vue单页面应用中实现Markdown渲染
2021/02/14 Vue.js
简单实现python收发邮件功能
2018/01/05 Python
对pandas中Series的map函数详解
2018/07/25 Python
python添加菜单图文讲解
2019/06/04 Python
对Python中TKinter模块中的Label组件实例详解
2019/06/14 Python
使用Python为中秋节绘制一块美味的月饼
2019/09/11 Python
Python-openCV读RGB通道图实例
2020/01/17 Python
Django serializer优化类视图的实现示例
2020/07/16 Python
vscode+PyQt5安装详解步骤
2020/08/12 Python
python-图片流传输的思路及示例(url转换二维码)
2020/12/21 Python
PHP如何删除一个Cookie值
2012/11/15 面试题
联想C++笔试题
2012/06/13 面试题
毕业生自荐信
2013/12/14 职场文书
幼儿园教研活动方案
2014/01/19 职场文书
个人现实表现材料
2014/02/04 职场文书
护理不良事件检讨书
2014/02/06 职场文书
幼儿园小班教师寄语
2014/04/03 职场文书
党性观念心得体会
2014/09/03 职场文书
作风转变年心得体会
2014/10/22 职场文书
2014年政教处工作总结
2014/12/20 职场文书
导游词格式
2015/02/13 职场文书
黄埔军校观后感
2015/06/10 职场文书
开学典礼校长致辞
2015/07/29 职场文书