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/*高 ...
随机推荐
- Flutter: IntrinsicWidth类,将孩子的宽度调整为孩子的最大内在宽度
文档 原文 class HomePage extends StatefulWidget { @override _HomePageState createState() => _HomePage ...
- Flutter: SliverAppBar 应用程序栏与滚动视图集成,以便它可以根据滚动偏移量在高度上变化
API class _MyHomeState extends State<MyHome> with SingleTickerProviderStateMixin { @override W ...
- NGK公链依靠技术创新推动数字经济产业发展
数字经济更让人们的生活发生了翻天覆地的变化.数字经济的发展要依靠技术的创新,发展出生态新模式.同时数字经济的发展要利用新技术对传统产业进行全面的的改造升级,释放数字对经济发展的放大.倍增作用.打造数字 ...
- keepalived-1.3.5+MHA部署mysql集群
MHA: MHA工作原理总结为以下几条: 从宕机崩溃的master保存二进制日志事件(binlog events): 识别含有最新更新的slave: 应用差异的中继日志(relay log)到其他sl ...
- Vue学习笔记-vue-element-admin 前端学习
一 使用环境 开发系统: windows 后端IDE: PyCharm 前端IDE: VSCode 数据库: msyql,navicat 编程语言: python3.7 (Windows x86- ...
- 下载HLS视频到本地
现在绝大多数网站播放视频都采用HLS技术,像腾讯优酷爱奇艺等等.本篇博文将介绍如何下载这样的视频到本地. 前言 因疫情影响,上课部分课程采用腾讯课堂上课,腾讯课堂有直播回放功能,但这个功能腾讯显然没有 ...
- docker封装nuxt项目使用jenkins发布
一.概述 vue项目可以打一个dist静态资源包,直接使用Nginx发布即可. 但是nuxt项目无法像vue那样,可以打一个dist静态资源包. 需要安装Node.js,并使用npm install ...
- vue核心---虚拟dom的实现
生成dom的过程 由vue模板生成虚拟dom 虚拟dom转换成真实dom渲染到html页面 代码实现 要实现的真实dom <div id="box"> <p cl ...
- eureka server 配置
启动类 import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure. ...
- Hi3559AV100外接UVC/MJPEG相机实时采图设计(二):V4L2接口的实现(以YUV422为例)
下面将给出Hi3559AV100外接UVC/MJPEG相机实时采图设计的整体流程,主要实现是通过V4L2接口将UVC/MJPEG相机采集的数据送入至MPP平台,经过VDEC.VPSS.VO最后通过HD ...