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

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

开始看书吧  记得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. Hibernate学习(二补充)关系映射----基于外键的双向一对一

    刚刚写的是基于外键的单向一对一.  那么双向一对一就是在单向一对一的基础上稍微改动就可以了. account.java和account.hbm.xml都不用变动  只要我们小小的变动address.j ...

  2. Docker + Jenkins 持续部署 ASP.NET Core 项目

    Docker 是个好东西,特别是用它来部署 ASP.NET Core Web 项目的时候,但是仅仅的让程序运行起来远远不能满足我的需求,如果能够像 DaoCloud 提供的持续集成服务那样,检测 gi ...

  3. 三、spring cloud 服务提供与调用

    如何使用eureka服务注册中心,搭建一个简单的服务端注册服务,客户端去调用服务使用. 案例中有三个角色:服务注册中心.服务提供者.服务消费者,eureka单机版启动既可,流程是首先启动注册中心,服务 ...

  4. android 实现银联刷卡机消费后,手动签名的功能

    几天前去物管交物业费,物管工作人员说小区引进高新产品,使用银行卡消费后,不需要拿笔在银联机上签名,直接用手指触摸实现消费签名,当时心想,果然是高科技,机子外形如下左图,签名如下右图.         ...

  5. [转]addEventListener() 方法,事件监听

    转载  白杨-M  http://www.cnblogs.com/baiyangyuanzi/p/6627401.html addEventListener() 方法,事件监听 你可以使用 remov ...

  6. css经典布局—stick footer布局

    html部分 <div id="wrap"> <div id="main" class="clearfix"> &l ...

  7. for in,Object.keys()与for of的区别

    for in 1.for in一般用于遍历对象的属性: 2.作用于数组的for in除了会遍历数组元素外,还会遍历自定义可枚举的属性,以及原型链上可枚举的属性:3.作用于数组的for in的遍历结果是 ...

  8. 【CSS3】盒模型

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  9. 【JMeter】source("文件路程")和${变量}同时出现会报错

    source("D:\\apache-jmeter-3.0\\testcase\\java\\Test.java"); //${journeyLen} 以上两句在JMeter脚本里 ...

  10. ES6之Symbol

    ES6中Symbol是为了防止属性名冲突而引入的,是独一无二的.Symbol值是通过Symbol函数生成.Symbol值不能与其他类型的值运算否则会报错且Symbol的值可以转换为字符串或者是布尔值但 ...