node初体验(一)
1.node.js是一个构建在chrome V8引擎上的javascript运行环境
2.node.js特点:单线程、事件驱动、非阻塞IO模型、轻量
3.node.js是单线程的(多个请求都是一个线程在处理)
4.事件驱动是node.js底层机制,有一个事件环,保证node.js可以高效准确的运行而不会错乱
5.模块化:
优点:
- 便于代码的重用
- 便于代码的维护
- 提高代码的可读性
- 降低代码的耦合性
问题:
- 如何定义模块
- 如何使用模块
- 模块依赖如何解决
标准的制定:
- CommonJS
- ES6
- AMD
- CMD
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初体验(一)的更多相关文章
- node初体验(二)
1.静态资源访问,需要设置路由和响应标头 2.url模块.path模块.querystring模块 Url { protocol: null, slashes: null, auth: null, h ...
- node.js 初体验
node.js 初体验 2011-10-31 22:56 by 聂微东, 174545 阅读, 118 评论, 收藏, 编辑 PS: ~ 此篇文章的进阶内容在为<Nodejs初阶之express ...
- node.js + express 初体验【hello world】
[node.js] 一个神奇的XX 呵呵 :) 不知道怎么形容他才好! [express] 是node.js 开发web应用程序的框架 开发环境:XP 大家共同进步吧 :) 一:前期准备: 1:下载 ...
- Node.js 网页瘸腿爬虫初体验
延续上一篇,想把自己博客的文档标题利用Node.js的request全提取出来,于是有了下面的初哥爬虫,水平有限,这只爬虫目前还有点瘸腿,请看官你指正了. // 内置http模块,提供了http服务器 ...
- 【腾讯Bugly干货分享】基于 Webpack & Vue & Vue-Router 的 SPA 初体验
本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/57d13a57132ff21c38110186 导语 最近这几年的前端圈子,由于 ...
- Flume日志采集系统——初体验(Logstash对比版)
这两天看了一下Flume的开发文档,并且体验了下Flume的使用. 本文就从如下的几个方面讲述下我的使用心得: 初体验--与Logstash的对比 安装部署 启动教程 参数与实例分析 Flume初体验 ...
- python--爬虫入门(七)urllib库初体验以及中文编码问题的探讨
python系列均基于python3.4环境 ---------@_@? --------------------------------------------------------------- ...
- grunt 构建工具(build tool)初体验
操作环境:win8 系统,建议使用 git bash (window下的命令行工具) 1,安装node.js 官网下载:https://nodejs.org/ 直接点击install ,会根据你的操 ...
- 基于 Webpack & Vue & Vue-Router 的 SPA 初体验
基于 Webpack & Vue & Vue-Router 的 SPA 初体验 本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com ...
随机推荐
- 用友GRP-u8 SQL注入
POST /Proxy HTTP/1.1 Accept: Accept: */* Content-Type: application/x-www-form-urlencoded User-Agent: ...
- Go语言学习-main和init
main 函数和 init 函数Go里面有两个保留的函数: init 函数(能够应用于所有的 package )和 main 函数(只能应用于 package main ).这两个函数在定义时不能有任 ...
- jqXHR.fail()回调方法及其参数详细说明
jqXHR.fail()是一个可供选择的 error 回调选项的构造函数,.fail()方法取代了的过时的.error()方法.从 jQuery 1.5 开始,$.ajax()返回的jqXHR对象 实 ...
- 狂神说SpringBoot11:Thymeleaf模板引擎
狂神说SpringBoot系列连载课程,通俗易懂,基于SpringBoot2.2.5版本,欢迎各位狂粉转发关注学习. 微信公众号:狂神说(首发) Bilibili:狂神说Java(视频) 未经作 ...
- 【BFS】hdu 1973 Prime Path
题目描述: http://poj.org/problem?id=3414 中文大意: 使用两个锅,盛取定量水. 两个锅的容量和目标水量由用户输入. 允许的操作有:灌满锅.倒光锅内的水.一个锅中的水倒入 ...
- Hive调优相关
前言 Hive是由Facebook 开源用于解决海量结构化日志的数据统计,是基于Hadoop 的一个数据仓库工具,可以将结构化的数据文件映射为一张表,并提供类 SQL查询功能. 在资源有限的情况下,提 ...
- 一文弄懂-Netty核心功能及线程模型
目录 一. Netty是什么? 二. Netty 的使用场景 三. Netty通讯示例 1. Netty的maven依赖 2. 服务端代码 3. 客户端代码 四. Netty线程模型 五. Netty ...
- 动态规划TG.lv(1) (洛谷提高历练地)
动态规划TG.lv(1) P1005 矩阵取数游戏 分析:每行不超过80个数字,直接区间DP即可,\(dp[i][j]\)表示区间\([i,j]\)之间取数可以得到的答案,每次向右或者向左扩展即可.但 ...
- Find a multiple POJ - 2356 容斥原理(鸠巢原理)
1 /* 2 这道题用到了鸠巢原理又名容斥原理,我的参考链接:https://blog.csdn.net/guoyangfan_/article/details/102559097 3 4 题意: 5 ...
- Keywords Search HDU - 2222 AC自动机板子题
In the modern time, Search engine came into the life of everybody like Google, Baidu, etc. Wiskey al ...