处在国企单位,整天闲的要死要死的,民族的花朵都快枯萎了

哎呀呀,打起精神.......早睡早起,多看书。。。开始进入苦读状态,苦练武功,争取有朝一日报效祖国。。。哈哈  开玩笑的

开始看书吧  记得Node.js+MonogoDB+AngularJs 这本书好像是去年4月份买的  买了好久了 一直没领会他的精髓  上班没事  绝对再看看  虽然对我的工作没什么帮助,哎呀呀  还是看吧.....................

一、node的事件模型:包含了事件队列、事件循环、线程池

二、实现定时器:

超时时间:延迟一段时间执行,只需要执行一次setTimeout();clearTimeout()取消超时时间函数

时间间隔:按定期的延迟时间间隔执行工作,对于定期工作setInterval();

即时计时器:setImmediate();允许你把工作调度为在时间队列中的当前事件完成之后执行,即在I/O事件的回调函数开始执行之后

process. nextTick:调度工作,在I/O时间被触发之前执行

从事件循环中取消定时器引用:unref()/ref()重新引用

三、事件发射器和监听器:

创建自定义事件:

四、Node.js处理数据:

数据形式有:文本、JSON字符串、二进制缓冲区、数据流

1、处理json

Json字符串转js对象:JSON.parse(String);转化为对象用点来访问

js对象转为JSON字符串:JSON.stringify();

2.使用buffer管理二进制的缓冲数据

(缓冲数据:有字节组成,比文本数据占用较少空间)

node.js提供buffer(缓冲区模块,全局性的,不需要require()引入)允许在缓冲结构中创建、读取、写入和操作二进制数据

创建缓冲区:new Buffer();

写入缓冲区:buffer.writer();

读取缓冲区:tostring();

确定缓冲区长度:buffer.length();返回的是字节长度

复制缓冲区:buffer.copy(new_buffer);

缓冲区切片:buffer.slice(start,end);

拼接缓冲区:Buffer.concat();

3.使用Stream模块来传送数据流

(stream模块是node的重要模块。数据流是可读、可写、或者即可读又可写的内存结构)

流的目的是从一个地方向另一个地方传送数据的通用机制;流一般用于HTTP数据和文件

Readable流(可读流):

常见实例:在客户端的HTTP相应、在服务器的HTTP请求、fs读取流、zlib流、crypto(加密)流、TCP套接字、子进程的stdout和stderr、process.stdin

公开事件:readable/data/end/close/error

方法:read():从流中读取数据。可以返回string对象、buffer对象或者null

setEncoding();设置从read()请求读取返回string的编码

pause();暂停从该对象发出的data事件

resume():恢复从该对象发出的data事件

pipe(de,[options]);把这个流的输出传输到由de目的地指定的writable流对象

unpipe():从写入的目的地断开这一对象

Writable流(可写流):

把数据写入一种可以轻松的在代码的另一个区域被使用的形式的机制

常见实例:客户端上的HTTP请求、服务骑上的HTTP响应、fs写入流、zlib流、crypto(加密)流、TCP套接字、子进程的stdin、process.stdout/process.stderr

公开事件:drain/finish/pipe/unpipe

方法:

.................................哟嘿 下班了  ...明天继续

闲来无事,把node又拾起来看看的更多相关文章

  1. babeljs源码

    babel.min.js!function(e,t){"object"==typeof exports&&"object"==typeof mo ...

  2. Node入门(转)

    原文链接:http://www.nodebeginner.org/index-zh-cn.html Node入门 作者: Manuel Kiessling翻译: goddyzhao & Gra ...

  3. 原生js编写的安全色拾色器

    <html > <head> <meta http-equiv="Content-Type" content="text/html; cha ...

  4. Node初学者入门,一本全面的NodeJS教程(转载)

    分类 JS学习   发布 ourjs  2013-12-02 注意 转载须保留原文链接,译文链接,作者译者等信息.     作者: Manuel Kiessling  翻译: goddyzhao &a ...

  5. Node.js 项目搭建

    关于 本书致力于教会你如何用Node.js来开发应用,过程中会传授你所有所需的“高级”JavaScript知识.本书绝不是一本“Hello World”的教程. 状态 你正在阅读的已经是本书的最终版. ...

  6. e2e 自动化集成测试 环境搭建 Node.js Selenium WebDriverIO Mocha Node-Inspector

    Node.js已经出来了许多年载,至今才开始接触.周未在家闲来无事,一时心血来潮,Google了大量的文章,经过实验,终于可以把整个环境给搭起来, 废话不多话,请看步骤. 特别注意, 本文章是针对Wi ...

  7. 【node.js】本地模式安装express:'express' 不是内部或外部命令,也不是可运行的程序或批处理文件。

    今天闲来无事想起了node.js,因此到网上下载了一个node.js的安装程序进行安装.其中: 安装程序:node-v0.11.13-x64.msi PC系统:Windows 7 自定义安装路径:D: ...

  8. ROS机器人程序设计(原书第2版)补充资料 (拾) 第十章 使用MoveIt!

    ROS机器人程序设计(原书第2版)补充资料 (拾) 第十章 使用MoveIt! 书中,大部分出现hydro的地方,直接替换为indigo或jade或kinetic,即可在对应版本中使用. MoveIt ...

  9. 非node环境下的vue.js 实现简单的购物车计算功能 样式请无视

    都说vue的双向数据绑定好用,自己用了下,感觉做购物车没想象中好用.自己的实现如下: <!DOCTYPE html> <html lang="en"> &l ...

随机推荐

  1. this的指向问题

    在 ES5 中,其实 this 的指向,始终坚持一个原理:this 永远指向最后调用它的那个对象. 例 1: var name = "windowsName"; function ...

  2. SSM框架开发web项目系列(四) MyBatis之快速掌握动态SQL

    前言 通过前面的MyBatis部分学习,已经可以使用MyBatis独立构建一个数据库程序,基本的增删查改/关联查询等等都可以实现了.简单的单表操作和关联查询在实际开的业务流程中一定会有,但是可能只会占 ...

  3. XMind常用快捷方式汇总

    快捷键(Windows) 快捷键(Mac) 描述 Ctrl+N Command+N 建立新工作簿 Ctrl+O Command+O 开启工作簿 Ctrl+S Command+S 储存目前工作簿 Ctr ...

  4. Pseudo-devices On GNU/Linux

    先分享一则有意思Q&A,来自The FreeBSD Funnies 17.4 . Where does data written to* /dev/null* go? ​ It goes in ...

  5. github not authorized eclipse 关于 代码不能提交到GitHub

    eclipse/myeclipse > menu > window > preferences > general > security > content > ...

  6. 小谈iOS屏幕适配问题

    首先,我么我们要观察一下5,6和6Plus的尺寸比例关系.发现了他们的关系后待会做兼容就明白了. 很明显能看出这三种屏幕的尺寸宽高比是差不多的,因此可以在5的基础上,按比例放大来兼容6和6Plus的屏 ...

  7. [array] leetcode-55. Jump Game - Medium

    leetcode-55. Jump Game - Medium descrition Given an array of non-negative integers, you are initiall ...

  8. 【读书笔记】《Effective Java》——目录

    第二章——创建和销毁对象 第1条:考虑用静态工厂方法替代构造器 第2条:遇到多个构造器参数时要考虑用构建器 第3条:用私有构造器或者枚举类型强化Singleton属性 第4条:通过私有构造器强化不可实 ...

  9. package-cleanup

    package-cleanup 是一个python开发的命令程序,用来清除本机已安装的.重复的 或孤立的软件包. desktop版的CentOS镜像包含这个工具,而Minimal版的CentOS镜像不 ...

  10. MarkDown的用法

    # 一级标题## 二级标题### 三级标题#### 四级标题##### 五级标题###### 六级标题# 无序标题- 文本- 文本- 文本# 有序标题1. 文本2. 文本3. 文本# 图片链接[张驰博 ...