Nodejs学习笔记

以前学习C、OC、Swift、H5的时候都没有留下痕迹,心里甚是遗憾,最近用Nodejs参与了一个web开发,果断留个纪念,供日后瞻仰。。。

菜鸟教程:http://www.runoob.com/nodejs/nodejs-install-setup.html

Github:https://github.com/Zyj163/Node.JS_learning(笔记,非demo)

环境配置:

方式一:http://nodejs.org下载安装(我用的这个)

方式二:使用终端(网上介绍的,没实验。。。)

1.安装home-brew

ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)

2.安装node

brew install node

当安装Node时会同时安装npm,npm是Node开发包管理器,用法省略。。。

使用:

先来一个Hello World

创建一个helloWorld.js的文件(我用的编辑器是webStorm)

var http = require('http');

http.createServer(function(req,res){

// 发送 HTTP 头部

// HTTP 状态值: 200 : OK

// 内容类型: text/plain

        res.writeHead(200, { 'Content-Type': 'text/plain' });

// 发送响应数据 "Hello World"

        res.end('Hello world!');

}).listen(3000);

console.log('Server started on localhost:3000; press Ctrl-C to terminate....');

打开终端,cd到当前目录,node hello World.js,然后打开浏览器访问http://localhost:3000即可

推荐一个好东西sudo npm install -g supervisor,cd到当前目录supervisor helloWorld.js,这样就不需要每次修改后台代码后,重启服务了,退出Ctrl+c

Node.js 是单进程单线程应用程序,但是通过事件和回调支持并发,所以性能非常高。Node 所有 API 都支持回调函数。

Node.js 的每一个 API 都是异步的,并作为一个独立线程运行,使用异步函数调用,并处理并发。

Node.js 基本上所有的事件机制都是用设计模式中观察者模式实现。

Node.js 单线程类似进入一个while(true)的事件循环,直到没有事件观察者退出,每个异步事件都生成一个事件观察者,如果有事件发生就调用该回调函数.

Node.js 使用事件驱动模型,当web server接收到请求,就把它关闭然后进行处理,然后去服务下一个web请求。当这个请求完成,它被放回处理队列,当到达队列开头,这个结果被返回给用户。引用runoob中的一张图


EventEmitter

Node.js 有多个内置的事件,我们可以通过引入 events 模块,并通过实例化 EventEmitter 类来绑定和监听事件

// 引入 events 模块

var events = require('events');

// 创建 eventEmitter 对象

var eventEmitter = new events.EventEmitter();

// 绑定事件及事件的处理程序

eventEmitter.on('eventName', eventHandler);

// 触发事件

eventEmitter.emit('eventName','arg1','arg2');

//移除指定事件的一个已经注册的监听器

eventEmitter.removeListener('eventName',eventHandler);

//移除指定事件的所有监听器

eventEmitter.removeAllListeners('eventName');

EventEmitter 对象如果在实例化时发生错误,会触发 'error' 事件。当添加新的监听器时,'newListener' 事件会触发,当监听器被移除时,'removeListener' 事件被触发。可以给同一事件创建多个监听,会被先后调用。

大多数时候我们不会直接使用 EventEmitter,而是在对象中继承它。 包括 fs、net、 http 在内的,只要是支持事件响应的核心模块都是 EventEmitter 的子类。


Buffer(缓冲区)

在 Node.js 中,Buffer 类是随 Node 内核一起发布的核心库。Buffer 库为 Node.js 带来了一种存储原始数据的方法,可以让 Node.js 处理二进制数据,每当需要在 Node.js 中处理I/O操作中移动的数据时,就有可能使用 Buffer 库。原始数据存储在 Buffer 类的实例中。一个 Buffer 类似于一个整数数组,但它对应于 V8 堆内存之外的一块原始内存。

//方法 1

//创建长度为 10 字节的 Buffer 实例:

var buf=newBuffer(10);

//方法 2

//通过给定的数组创建 Buffer 实例:

var buf2=newBuffer([10,20,30,40]);

//方法 3

//通过一个字符串来创建 Buffer 实例:

var buf3=newBuffer("www.runoob.com","utf-8");

/*写入

buf.write(string[, offset[, length]][, encoding])

参数

参数描述如下:

string - 写入缓冲区的字符串。

offset - 缓冲区开始写入的索引值,默认为 0 。

length - 写入的字节数,默认为 buffer.length

encoding - 使用的编码。默认为 'utf8' 。

* */

var len=buf.write('www.runoob.com');

console.log('写入字节数:'+len);

/*读取

buf.toString([encoding[, start[, end]]])

参数

参数描述如下:

encoding - 使用的编码。默认为 'utf8' 。

start - 指定开始读取的索引位置,默认为 0。

end - 结束位置,默认为缓冲区的末尾。

* */

var re=buf.toString();

//转为json对象

var json=buf.toJSON(buf);

//合并buffer

var buf4= Buffer.concat([buf,buf3]);

/*拷贝

buf.copy(targetBuffer[, targetStart[, sourceStart[, sourceEnd]]])

参数

参数描述如下:

targetBuffer - 要拷贝的 Buffer 对象。

targetStart - 数字, 可选, 默认: 0

sourceStart - 数字, 可选, 默认: 0

sourceEnd - 数字, 可选, 默认: buffer.length

* */

var buf5=newBuffer(10);

buf5.copy(but);


Stream(流)

Stream 对象都是 EventEmitter 的实例(对http 服务器发起请求的request 对象就是一个 Stream,所以request也有下面的事件)。常用的事件有:

data - 当有数据可读时触发。

end - 没有更多的数据可读时触发。

error - 在接收和写入过程中发生错误时触发。

finish - 所有数据已被写入到底层系统时触发。


从流中读数据:

var fs = require("fs");

var data = '';

// 创建可读流

var readerStream = fs.createReadStream('input.txt');

// 设置编码为 utf8。

readerStream.setEncoding('UTF8');

// 处理流事件 --> data, end, and error

readerStream.on('data', function(chunk) {

data += chunk;

});

readerStream.on('end',function(){

console.log(data);

});

readerStream.on('error', function(err){

console.log(err.stack);

});


写入流:

var fs = require("fs");

var data = '菜鸟教程官网地址:www.runoob.com';

// 创建一个可以写入的流,写入到文件 output.txt 中

var writerStream = fs.createWriteStream('output.txt');

// 使用 utf8 编码写入数据

writerStream.write(data,'UTF8');

// 标记文件末尾

writerStream.end();

// 处理流事件 --> data, end, and error

writerStream.on('finish', function() {

console.log("写入完成。");

});

writerStream.on('error', function(err){

console.log(err.stack);

});

console.log("程序执行完毕");


管道流:

var fs= require('fs')

var zlib= require('zlib')

//压缩

fs.createReadStream('input.txt')

   .pipe(zlib.createGzip())

   .pipe(fs.createWriteStream('input.zip'))

//解压

fs.createReadStream('input.zip')

.pipe(zlib.createGunzip())

.pipe(fs.createWriteStream('input.txt'))


模块系统:

1、提供函数:

定义:

exports.world = function() {}

使用:

var use = require('./world');

use.world();

2、提供对象:

定义:(fuc外面的东西可以理解为私有的,里面的是公开的)

function Hello() {

              var name;

              this.setName = function(thyName) {

                         name = thyName;

              };

              this.sayHello = function() {

                        console.log('Hello ' + name);

              };

};

module.exports = Hello;

使用:

var Hello = require('./hello');

hello = new Hello();

hello.setName('BYVoid');

hello.sayHello();


路由:

解析URL,引用url和querystring模块


全局对象与全局变量:

__filename 表示当前正在执行的脚本的文件名。它将输出文件所在位置的绝对路径,且和命令行参数所指定的文件名不一定相同。 如果在模块中,返回的值是模块文件的路径。

__dirname 表示当前执行脚本所在的目录。

process.memoryUsage() 输出内存使用情况


常用工具:

util.inherits(constructor, superConstructor)是一个实现对象间原型继承 的函数。JavaScript 的面向对象特性是基于原型的,与常见的基于类的不同。JavaScript 没有 提供对象继承的语言级别特性,而是通过原型复制来实现的。

var util= require('util');

functionBase(){

//不能继承

this.name='base';

this.base=1991;

this.sayHello=function(){

console.log('hello'+this.name);

}

}

//可以被继承

Base.prototype.showName=function(){

console.log(this.name);

};

functionSub(){

this.name='sub';

//Sub 仅仅继承了Base 在原型中定义的函数,而构造函数内部创造的 base 属 性和 sayHello 函数都没有被 Sub 继承。

}

util.inherits(Sub,Base);

varobjBase=newBase();

objBase.showName();

objBase.sayHello();

console.log(objBase);

varobjSub=newSub();

objSub.showName();

console.log(objSub);


util.inspect(object,[showHidden],[depth],[colors])是一个将任意对象转换 为字符串的方法,通常用于调试和错误输出。它至少接受一个参数 object,即要转换的对象。

更多详情可以访问 http://nodejs.org/api/util.html 了解详细内容

可以使用typeof some ==='function' 做类型判断


文件系统:

应该很多都需要知道,没必要截了http://www.runoob.com/nodejs/nodejs-fs.html


知道这些基础知识差不多就可以进行下一个目标express了,这个才是重点!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,530评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,403评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,120评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,770评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,758评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,649评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,021评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,675评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,931评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,751评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,410评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,004评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,969评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,042评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,493评论 2 343

推荐阅读更多精彩内容