1.node.js是一个构建在chrome V8引擎上的javascript运行环境

2.node.js特点:单线程、事件驱动、非阻塞IO模型、轻量

3.node.js是单线程的(多个请求都是一个线程在处理)

4.事件驱动是node.js底层机制,有一个事件环,保证node.js可以高效准确的运行而不会错乱

5.模块化:

优点:

  • 便于代码的重用
  • 便于代码的维护
  • 提高代码的可读性
  • 降低代码的耦合性

问题:

  • 如何定义模块
  • 如何使用模块
  • 模块依赖如何解决

标准的制定:

6.在node中,一个js文件就是一个模块,每一个js文件中的代码都是独立运行在一个函数中的,而不是在全局作用域,所以说一个模块中的变量和函数在其它模块中是无法访问的

7.通过require()函数来引入外部的模块,使用require()引入模块后,会返回一个对象,这个对象代表的是被引入的模块

8.模块分成两大类(模块标识就是require()里面的字符串)

  • 核心模块

由node提供的模块,核心模块的标识就是模块的名字

  • 文件模块

由用户自己创建,文件模块的标识就是文件的路径

9.通过exports来向外暴露变量和方法

10.在node中有一个global,作用和浏览器中的window类似,在全局中创建的变量都会作为global的属性保存

  • a=0 ,这时候是全局变量 | var a=0,这时候是局部变量

-在node执行模块中的代码时,它会首先在代码的最顶部,添加如下代码

function (exports,require,module,__filename,__dirname){

内部是我们自己编写的代码

export(export是module.export属性)

  • 使用该对象将变量和函数进行暴露

require

  • 用来引用外部的模块

module

  • 代表当前模块本身

__filename

  • 当前模块的完整的路径

__dirname

  • 当前模块所在文件夹的完整路径

在代码的最底部添加如下代码

}

11.export和module.export区别

ModuleG.js代码

var x = "ModuleG x"
var y = "ModuleG y" function fun() {
console.log("ModuleG fun is called")
} //向外暴露
// exports.x = x
// exports.y = y
// exports.fun = fun // module.exports.x = x
// module.exports.y = y
// module.exports.fun = fun // OK
// module.exports = {
// x, y, fun
// } // error
exports = {
x, y, fun
}

ModuleF.js代码


var moduleG = require("./ModuleG") console.log(moduleG.x)
console.log(moduleG.y)
moduleG.fun()

结论(区别)

  • exports在以对象形式{}导出的时候会报错
  • 在以对象形式导出时module.exports没有修改地址,exports修改地址

12.包(包规范由包结构和包描述文件组成)

包结构(包中各种文件)

  • package.json 包的描述文件
  • bin 可执行二进制文件
  • lib js(第三方依赖库)
  • doc 文档
  • test 单元测试

包描述文件

描述包的相关信息,供外部读取分析

  • name: 项目/模块的名称

  • version: 项目版本

  • author: 项目的作者

  • description: 项目的描述

  • keywords: 项目关键字

  • contributors: 项目的贡献者

  • respository: 项目的仓库

  • homepage: 项目的官方地址

  • dependencies: 生产环境依赖

  • devDependencies: 开发环境依赖

  • scripts: 执行npm脚本命令的简写

13.npm命令

  • npm -v
  • npm search 包名
  • npm init 包初始化
  • npm install 包名
  • npm install 包名 --save
  • npm install 包名 --save-dev
  • npm install 包名 -g
  • npm remove 包名

14.nrm切换npm源

  • npm install -g nrm 安装
  • nrm ls 查看
  • nrm use xxx 切换

15.node搜索包的流程

node在使用模块名称来引入模块时,先在当前目录的node_modules文件夹中查找,如果没有找到,再到上一级目录去找,一直递归查找到磁盘根目录

16.npm包发布流程

  • npm init
  • 建立index.js及其它
  • npm login
  • npm publish

附录可能出现的错误:

  • 源不对,淘宝不能提交
500 Internal Server Error - PUT https://registry.npm.taobao.org/-/user/org.couchdb.user:xxx
  • 被占用
 You do not have permission to publish "npm_test".

下载安装

npm install xxx

17.Buffer缓冲区

从结构上看Buffer和数组相似,它的元素是16进制的两位数

数组中不能存储二进制的文件,而buffer专门用来存储二进制数

实际上每个元素代表内存中的一个字节 范围从00-ff 0-255

使用Buffer不需要引入模块,直接使用,默认编码是utf8

Buffer一旦设定大小就不能改变

  • Buffer.from(str)将一个字符串转换成buffer
  • Buffer.alloc() 创建一个指定大小的Buffer
  • Buffer.allocsafe() 不安全,有就内存数据,不重新分配新的空间
  • buf.tostring() 将缓冲区的数据转成字符串
fs.read(fd, buffer, offset, length, position, callback);

 * fd, 使用fs.open打开成功后返回的文件描述符
* buffer, 一个Buffer对象,v8引擎分配的一段内存
* offset, 整数,向缓存区中写入时的初始位置,以字节为单位
* length, 整数,读取文件的长度
* position, 整数,读取文件初始位置;文件大小以字节为单位
* callback(err, bytesRead, buffer), 读取执行完成后回调函数,bytesRead实际读取字节数,被读取的缓存区对象
  • fs.write会擦除之前的内容

  • fs.writeFile是对fs.write的open和close的封装

  • on和once区别,once只执行一次

下面的on("data")是每取一小部分data就触发一次,读取到data的buffer里面

- re.on("data",function(data){
ws.write(data)
})
  • ws.end()放在re的可读流里面更好
  • pipe管道文件使得读写更方便

附言:这个是第一篇小白写的比较长的总结,难免会有错误,有误的地方欢迎斧正

附言: node知识来自

- node中文网

- IT老兵

- 博客网、CSDN、百度

node初体验(一)的更多相关文章

  1. node初体验(二)

    1.静态资源访问,需要设置路由和响应标头 2.url模块.path模块.querystring模块 Url { protocol: null, slashes: null, auth: null, h ...

  2. node.js 初体验

    node.js 初体验 2011-10-31 22:56 by 聂微东, 174545 阅读, 118 评论, 收藏, 编辑 PS: ~ 此篇文章的进阶内容在为<Nodejs初阶之express ...

  3. node.js + express 初体验【hello world】

    [node.js]  一个神奇的XX 呵呵 :) 不知道怎么形容他才好! [express] 是node.js 开发web应用程序的框架 开发环境:XP 大家共同进步吧 :) 一:前期准备: 1:下载 ...

  4. Node.js 网页瘸腿爬虫初体验

    延续上一篇,想把自己博客的文档标题利用Node.js的request全提取出来,于是有了下面的初哥爬虫,水平有限,这只爬虫目前还有点瘸腿,请看官你指正了. // 内置http模块,提供了http服务器 ...

  5. 【腾讯Bugly干货分享】基于 Webpack & Vue & Vue-Router 的 SPA 初体验

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57d13a57132ff21c38110186 导语 最近这几年的前端圈子,由于 ...

  6. Flume日志采集系统——初体验(Logstash对比版)

    这两天看了一下Flume的开发文档,并且体验了下Flume的使用. 本文就从如下的几个方面讲述下我的使用心得: 初体验--与Logstash的对比 安装部署 启动教程 参数与实例分析 Flume初体验 ...

  7. python--爬虫入门(七)urllib库初体验以及中文编码问题的探讨

    python系列均基于python3.4环境 ---------@_@? --------------------------------------------------------------- ...

  8. grunt 构建工具(build tool)初体验

    操作环境:win8 系统,建议使用 git bash (window下的命令行工具) 1,安装node.js 官网下载:https://nodejs.org/  直接点击install ,会根据你的操 ...

  9. 基于 Webpack & Vue & Vue-Router 的 SPA 初体验

    基于 Webpack & Vue & Vue-Router 的 SPA 初体验 本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com ...

随机推荐

  1. 用友GRP-u8 SQL注入

    POST /Proxy HTTP/1.1 Accept: Accept: */* Content-Type: application/x-www-form-urlencoded User-Agent: ...

  2. Go语言学习-main和init

    main 函数和 init 函数Go里面有两个保留的函数: init 函数(能够应用于所有的 package )和 main 函数(只能应用于 package main ).这两个函数在定义时不能有任 ...

  3. jqXHR.fail()回调方法及其参数详细说明

    jqXHR.fail()是一个可供选择的 error 回调选项的构造函数,.fail()方法取代了的过时的.error()方法.从 jQuery 1.5 开始,$.ajax()返回的jqXHR对象 实 ...

  4. 狂神说SpringBoot11:Thymeleaf模板引擎

    狂神说SpringBoot系列连载课程,通俗易懂,基于SpringBoot2.2.5版本,欢迎各位狂粉转发关注学习. 微信公众号:狂神说(首发)    Bilibili:狂神说Java(视频) 未经作 ...

  5. 【BFS】hdu 1973 Prime Path

    题目描述: http://poj.org/problem?id=3414 中文大意: 使用两个锅,盛取定量水. 两个锅的容量和目标水量由用户输入. 允许的操作有:灌满锅.倒光锅内的水.一个锅中的水倒入 ...

  6. Hive调优相关

    前言 Hive是由Facebook 开源用于解决海量结构化日志的数据统计,是基于Hadoop 的一个数据仓库工具,可以将结构化的数据文件映射为一张表,并提供类 SQL查询功能. 在资源有限的情况下,提 ...

  7. 一文弄懂-Netty核心功能及线程模型

    目录 一. Netty是什么? 二. Netty 的使用场景 三. Netty通讯示例 1. Netty的maven依赖 2. 服务端代码 3. 客户端代码 四. Netty线程模型 五. Netty ...

  8. 动态规划TG.lv(1) (洛谷提高历练地)

    动态规划TG.lv(1) P1005 矩阵取数游戏 分析:每行不超过80个数字,直接区间DP即可,\(dp[i][j]\)表示区间\([i,j]\)之间取数可以得到的答案,每次向右或者向左扩展即可.但 ...

  9. Find a multiple POJ - 2356 容斥原理(鸠巢原理)

    1 /* 2 这道题用到了鸠巢原理又名容斥原理,我的参考链接:https://blog.csdn.net/guoyangfan_/article/details/102559097 3 4 题意: 5 ...

  10. Keywords Search HDU - 2222 AC自动机板子题

    In the modern time, Search engine came into the life of everybody like Google, Baidu, etc. Wiskey al ...