Nodejs入门(二)
Nodejs基础api
1、path
path模块提供了很多实用的工具函数,用于处理文件与目录的路径,下面是它的api:
normalize 方法可以输出规范格式的path字符串
join 方法用于拼接path字符串
resolve 方法用于将相对路径解析为绝对路径
name 方法用于查看文件名
- basename查看文件名
- dirname查看所在路径
- extname查看扩展名
parse与format,parse用于将一个路径字符串返回成一个对象,而format则正好相反,如果有时候你需要修改一个路径的话,就可以先parse修改之后再format回去
delimiter 提供不同系统下的分隔符,windows系统(;)和posix(:)系统分隔符不同。sep 返回各平台的分隔符(Windows\,POSIX/)
//delimiter
console.log(process.env.PATH)
'C:\Windows\system32;C:\Windows;C:\Program Files\node'process.env.PATH.split(path.delimiter)
['C:\Windows\system32', 'C:\Windows', 'C:\Program Files\node\']//sep
'foo\bar\baz'.split(path.sep)
返回:['foo','bar','baz']
path路径需要注意的一些地方
- _dirname、_filename总是返回文件的绝对路径
- process.cwd( )总是返回执行node命令所在文件夹
2、Buffer(缓冲)
Buffer是global对象的属性,用于处理二进制数据流。它的实例类似整数数组,但是它里面是一些0-255的数字(默认用十六进制表示)大小固定。且用C++代码在V8堆外分配物理内存
如何实例化Buffer:
- Buffer.alloc( length ) or Buffer.alloc( length,1 )
- Buffer.allocUnsafe( length ) // 它较于alloc的区别是没做初始化,这样速度快,但内存块原来有的东西没清空,所以要用fill( )于write( )把里面的内容重写一下
- Buffer.from( [1,2,3] ) or Buffer.form( 字符串 , 编码格式)
以下是它的类的一些常用方法:
- Buffer.byteLength 返回一个字符串的实际字节长度
- Buffer.isBuffer( ) 判断是否时buffer对象
- Buffer.concat( ) 拼接buffer,传入的参数是一个数组
再看下实例的属性
- buf.length 返回 buf 在字节数上分配的内存量
- buf.toString( ) 根据指定的字符编码解码 buf 成一个字符串
- buf.fill( ) 用于填充buf
- buf.equals( ) 比较两个buf的内容是否一样
- buf.indexOf( ) 用于查找匹配
- buf.copy( )
3、event
Nodejs所有能触发事件的对象都是EventEmitter类的实例,这些对象开放了一个 eventEmitter.on() 函数,允许将一个或多个函数绑定到会被对象触发的命名事件上。
eventEmitter.on() 方法用于注册监听器,eventEmitter.emit() 方法用于触发事件。
const EventEmiter = require('events');
class triggerEvent extends EventEmiter {}
const ex = new triggerEvent();//实例化
ex.on("error",(err,time) => {
console.log(err);
console.log(time)
});//事件绑定
ex.emit("err",new Error("opps!"),Date.now());//手动触发事件,并传两个参数
Nodejs事件的绑定还可以用once进行绑定,让事件只触发一次。
而事件可以通过removeListener(event name,function name)进行移除,或者使用removeAllListeners(event name)移除所有
4、fs(文件系统)
fs 模块提供了一些 API,用于以一种类似标准 POSIX 函数的方式与文件系统进行交互。
所有的文件系统操作都有异步和同步两种形式。
异步形式的最后一个参数都是完成时回调函数。 传给回调函数的参数取决于具体方法,但回调函数的第一个参数都会保留给异常。
- fs.readFile( ) 读取文件
const fs = require("fs");
fs.readFile("./event.js",'utf8',(err,data) => {
if(err) {
throw err;
} else {
console.log(data);
}
})//异步读取文件
const data = fs.readFileSync("./event.js",'utf-8');//同步读取文件
console.log(data);
- fs.writeFile( ) 写入文件
const fs = require("fs");
const content = Buffer.from("balabalabala");
fs.writeFile("./text",content,err => {
if(err){
throw err;
} else {
console.log("done !");
}
})
- fs.stat( ) 输出文件的stats属性
const fs = require("fs");
fs.stat("stat.js", (err,stats) => {
if(err) {
console.log("文件不存在!");
return;
} else {
console.log(stats.isFile());//是否为文件
console.log(stats.isDirectory());//是否为文件夹
}
})
- fs.watch( ) 监视文件或者文件夹
const fs = require("fs");
fs.watch('./',{
recursive: true //指明是否全部子目录应该被监视,或只是当前目录。
},(eventType,filename) => {
console.log("变化类型",eventType);
console.log("变化的文件名",filename);
})
- fs.createReadStream( ) 创建数据流,读取数据
数据是一点点流动的,不是全部接受,相较于fs.readFile( )会显得更加优雅
const fs = require("fs");
const rs = fs.createReadStream('./readstream.js');
rs.pipe(process.stdout);//数据导向哪里,stdout就是控制台
- fs.createWriteStream( ) 创建数据流,写入数据
同fs.createReadStream( ),它是一种优雅的写入数据的方式
const fs = require("fs");
const ws = fs.createWriteStream('./test.txt');
const timer = setInterval(() => {
const num = parseInt(Math.random() * 10);//取19以内的随机数
if(num < 8){
ws.write(num + '');//转换为字符串,因为只能写入buffer或者字符串
} else {
clearInterval(timer);//清楚定时器
ws.end();//结束写入数据流
}
},1000);//每个一秒写入一段数据
ws.on("finish",() => {
console.log("done!");
});//监听事件结束
下面还有一些常用的api:
- fs.rename( ) 修改文件名
- fs.unlink( ) 删除文件
- fs.readdir( ) 读取文件夹下的所有文件名
- fs.mkdir( ) 创建文件夹
- fs.rmdir( ) 删除文件夹
Nodejs入门(二)的更多相关文章
- 二、NodeJS入门——准备工作(2)——MongoDB安装以及客户端Robomongo安装和使用
目录 1.介绍 2.下载地址 3.MongoDB安装过程 4.MongoDB的使用 5.MongoDB添加管理员账户 6.RoboMongo安装过程 ...
- NodeJS入门简介
NodeJS入门简介 二.模块 在Node.js中,以模块为单位划分所有功能,并且提供了一个完整的模块加载机制,这时的我们可以将应用程序划分为各个不同的部分. const http = require ...
- nodeJs 5.0.0 安装配置与nodeJs入门例子学习
新手学习笔记,高手请自动略过 安装可以先看这篇:http://blog.csdn.net/bushizhuanjia/article/details/7915017 1.首先到官网去下载exe,或者m ...
- NodeJS入门(四)—— path对象
很快Node就会迎来4.0的时代,届时将并入现有的iojs,所以先前写过的iojs入门系列直接更名为NodeJS入门. 本篇开始将逐个介绍Node的各主要模块,依循API文档走一遍,但会给出比API文 ...
- 【原创】NIO框架入门(二):服务端基于MINA2的UDP双向通信Demo演示
前言 NIO框架的流行,使得开发大并发.高性能的互联网服务端成为可能.这其中最流行的无非就是MINA和Netty了,MINA目前的主要版本是MINA2.而Netty的主要版本是Netty3和Netty ...
- Swift语法基础入门二(数组, 字典, 字符串)
Swift语法基础入门二(数组, 字典, 字符串) 数组(有序数据的集) *格式 : [] / Int / Array() let 不可变数组 var 可变数组 注意: 不需要改变集合的时候创建不可变 ...
- Thinkphp入门 二 —空操作、空模块、模块分组、前置操作、后置操作、跨模块调用(46)
原文:Thinkphp入门 二 -空操作.空模块.模块分组.前置操作.后置操作.跨模块调用(46) [空操作处理] 看下列图: 实际情况:我们的User控制器没有hello()这个方法 一个对象去访问 ...
- DevExpress XtraReports 入门二 创建 data-aware(数据感知) 报表
原文:DevExpress XtraReports 入门二 创建 data-aware(数据感知) 报表 本文只是为了帮助初次接触或是需要DevExpress XtraReports报表的人群使用的, ...
- 01.Nodejs入门之Helloworld
说明:本文章可供有一定js基础的朋友参考nodejs入门,本文未讲解nodejs的安装,如有需要的同学可以加QQ3382260752找我,进行交流学习. 1.新建文件夹helloworld demo, ...
- css入门二-常用样式
css入门二-常用样式总结 基本标签样式 背景色background-color 高度height; 宽度width; 边框对齐以及详细设定举例 width/*宽度*/: 80%; height/*高 ...
随机推荐
- 算法型稳定币USDN是如何保持稳定的?
数据显示,2019年稳定币市场总市值25亿美元,在整个加密货币市场占比 1.3%.可别小瞧了看似微小的1.3%这个数据,它其实是一个庞大的市场.稳定币不仅仅是货币的电子化,它还是一种可编程的加密货币, ...
- linux系统解压命令总结
原文链接:https://www.cnblogs.com/lhm166/articles/6604852.html tar -c: 建立压缩档案 -x:解压 -t:查看内容 -r:向压缩归档文件末尾追 ...
- 将VMware虚拟机最小化到托盘栏
版权:本文采用「署名-非商业性使用-相同方式共享 4.0 国际」知识共享许可协议进行许可. 目录 前言 将VMware最小化到托盘栏的方法 1.下载 Trayconizer 2.解压 trayco ...
- ServiceMesh
传统微服务架构 在微服务模式下,企业内部服务少则几个到几十个,多则上百个,每个服务一般都以集群方式部署,这时自然产生两个问题: 一.服务发现:服务的消费方(Consumer)如何发现服务的提供方(Pr ...
- Linux文本三剑客总结
Linux文本处理三剑客 grep 文本过滤(模式:pattern)工具 grep, egrep, fgrep(不支持正则表达式搜索) grep grep: Global search REgula ...
- 腾讯一面问我SQL语句中where条件为什么写上1=1
目录 where后面加"1=1″还是不加 不用where 1=1 在多条件查询的困惑 使用where 1=1 的好处 使用where 1=1 的坏处 where后面加"1=1″还是 ...
- PAT-1102(Invert a Binary Tree)+二叉树的镜像+层次遍历+中序遍历+已知树的结构构树
Invert a Binary Tree pat-1102 import java.util.Arrays; import java.util.Queue; import java.util.Scan ...
- Amazon Connect 配置ccp端的soft phone配置(客服坐席工作站配置)
本文参考: Amazon Connect 配置ccp端的soft phone配置(客服坐席工作站配置) [官网]:https://aws.amazon.com/cn/connect/ 应用场景 在应 ...
- threejs 基础概要
threejs 基础概要 点击查看官方文档 下面是翻译的内容(稍作修改) 先了解一下Three.js应用程序的结构.Three.js应用程序需要创建一堆对象并将它们连接在一起.下图表示一个小three ...
- 爬虫必知必会(6)_提升scrapy框架爬取数据的效率之配置篇
如何提升scrapy爬取数据的效率:只需要将如下五个步骤配置在配置文件中即可 增加并发:默认scrapy开启的并发线程为32个,可以适当进行增加.在settings配置文件中修改CONCURRENT_ ...