官网传送门
Node.js® is a Javascript runtime built on Chrome’s V8 Javascript engine
Node.js® 是一个基于 Chrome V8 引擎 的 Javascript 运行时环境
Buffer 缓冲区文档
Buffer 常用方法:
Buffer.from(str[, encoding])
:将一个字符串转换为 BufferBuffer.alloc(size)
:创建指定大小的 BufferBuffer.alloUnsafe(size)
:创建指定大小的 Buffer,可能包含敏感数据(分配内存时不会清除内存残留的数据)buf.toString()
:将 Buffer 数据转为字符串var str = 'Hello前端'var buf = Buffer.from(str)// 占用内存的大小,一个汉字3字节 13
console.log(buf.length)
// 字符串的长度 7
console.log(str.length)
// 8进制输出第一个元素 145
console.log(buf[1].toString(8))//创建一个10个字节的buffer
var buf2 = Buffer.alloc(10)
//通过索引,来操作buf中的元素
buf2[0] = 88
buf2[1] = 255
buf2[2] = 0xaa
buf2[3] = 255var buf3 = Buffer.allocUnsafe(10)
console.log(buf3)
打开模式:
模式 | 说明 |
---|---|
r | 读取文件,文件不存在抛异常 |
r+ | 读写文件,文件不存在抛异常 |
rs | 同步模式下打开文件用于读取 |
rs+ | 同步模式下打开文件用于读写 |
w | 写文件,不存在则创建,存在则覆盖原有内容 |
wx | 写文件,文件存在打开失败 |
w+ | 读写文件,不存在创建,存在截断 |
wx+ | 读写,存在打开失败 |
a | 追加,不存在创建 |
ax | 追加,存在失败 |
a+ | 追加和读取,不存在创建 |
ax+ | 追加和读取,存在失败 |
语法格式:
fs.readFile(path[, options], callback)
path
:文件路径options
:配置选项,若是字符串则指定编码格式 encoding
:编码格式flag
:打开方式callback
:回调函数 err
:错误信息data
:读取的数据,如果未指定编码格式则返回一个 Bufferconst fs = require('fs')fs.readFile('./files/1.txt', 'utf-8', function(err, data) => {if(err) {return console.log('failed!' + err.message)}console.log('content:' + data)
})// 复制文件内容
fs.readFile("C:/Users/笔记.mp3", function(err, data) {if(!err) {console.log(data);// 将data写入到文件中fs.writeFile("C:/Users/hello.jpg", data, function(err){if(!err){console.log("文件写入成功");}} );}
});
var fs = require('fs')// 创建一个可读流
var rs = fs.createReadStream('C:/Users/笔记.mp3')
// 创建一个可写流
var ws = fs.createWriteStream('a.mp3')// 监听流的开启和关闭
// 这几个监听不是必须的
rs.once('open', function () {console.log('可读流打开了~~')
})rs.once('close', function () {console.log('可读流关闭了~~')//数据读取完毕,关闭可写流ws.end()
})ws.once('open', function () {console.log('可写流打开了~~')
})ws.once('close', function () {console.log('可写流关闭了~~')
})//要读取一个可读流中的数据,要为可读流绑定一个data事件,data事件绑定完毕自动开始读取数据
rs.on('data', function (data) {console.log(data)//将读取到的数据写入到可写流中ws.write(data)
})
简便方式:
var fs = require('fs')var rs = fs.createReadStream('C:/Users/lilichao/Desktop/笔记.mp3')
var ws = fs.createWriteStream('b.mp3')// pipe()可以将可读流中的内容,直接输出到可写流中
rs.pipe(ws)
语法格式:
fs.writeFile(file, data[, options], callback)
file
:文件路径data
:写入内容options
:配置选项,包含 encoding, mode, flag
;若是字符串则指定编码格式callback
:回调函数const fs = require('fs')
fs.writeFile('./files/2.txt', 'Hello Nodejs', function (err) {if (err) {return console.log('failed!' + err.message)}console.log('success!')
})fs.writeFile('C:/Users/hello.txt', '通过 writeFile 写入的内容', { flag: 'w' }, function (err) {if (!err) {console.log('写入成功!')} else {console.log(err)}
})
// 同步、异步、简单文件的写入都不适合大文件的写入,性能较差,容易导致内存溢出
var fs = require('fs')// 创建一个可写流
var ws = fs.createWriteStream('hello3.txt')ws.once('open', function () {console.log('流打开了~~')
})ws.once('close', function () {console.log('流关闭了~~')
})// 通过ws向文件中输出内容
ws.write('通过可写流写入文件的内容')
ws.write('1')
ws.write('2')
ws.write('3')
ws.write('4')// 关闭流
ws.end()
__dirname
./
或 ../
开头的相对路径时,容易出现路径动态拼接错误的问题__dirname
获取文件所处的绝对路径fs.readFile(__dirname + '/files/1.txt', 'utf8', function(err, data) {...
})
验证路径是否存在:
fs.exists(path, callback)
fs.existsSync(path)
获取文件信息:
fs.stat(path, callback)
fs.stat(path)
删除文件:
fs.unlink(path, callback)
fs.unlinkSync(path)
列出文件:
fs.readdir(path[,options], callback)
fs.readdirSync(path[, options])
截断文件:
fs.truncate(path, len, callback)
fs.truncateSync(path, len)
建立目录:
fs.mkdir(path[, mode], callback)
fs.mkdirSync(path[, mode])
删除目录:
fs.rmdir(path, callback)
fs.rmdirSync(path)
重命名文件和目录:
fs.rename(oldPath, newPath, callback)
fs.renameSync(oldPath, newPath)
监视文件更改:
fs.watchFile(filename[, options], listener)
path 模块是 Node.js 官方提供的、用来处理路径的模块。它提供了一系列的方法和属性,用来满足用户对路径的处理需求。
path.join()
const path = require('path')
const fs = require('fs')// 注意 ../ 会抵消前面的路径
// ./ 会被忽略
const pathStr = path.join('/a', '/b/c', '../../', './d', 'e')
console.log(pathStr) // \a\d\efs.readFile(path.join(__dirname, './files/1.txt'), 'utf8', function (err, dataStr) {if (err) {return console.log(err.message)}console.log(dataStr)
})
path.basename()
使用 path.basename()
方法,可以获取路径中的最后一部分,常通过该方法获取路径中的文件名
path.basename(path[, ext])
const path = require('path')// 定义文件的存放路径
const fpath = '/a/b/c/index.html'const fullName = path.basename(fpath)
console.log(fullName) // index.htmlconst nameWithoutExt = path.basename(fpath, '.html')
console.log(nameWithoutExt) // index
path.extname()
const path = require('path')const fpath = '/a/b/c/index.html'const fext = path.extname(fpath)
console.log(fext) // .html
http 模块是 Node.js 官方提供的、用来创建 web 服务器的模块。
const http = require('http')// 创建 web 服务器实例
const server = http.createServer()// 为服务器实例绑定 request 事件,监听客户端的请求
server.on('request', function (req, res) {const url = req.urlconst method = req.methodconst str = `Your request url is ${url}, and request method is ${method}`console.log(str)// 设置 Content-Type 响应头,解决中文乱码的问题res.setHeader('Content-Type', 'text/html; charset=utf-8')// 向客户端响应内容res.end(str)
})server.listen(8080, function () {console.log('server running at http://127.0.0.1:8080')
})
const http = require('http')
const server = http.createServer()server.on('request', (req, res) => {const url = req.url// 设置默认的响应内容为 404 Not foundlet content = '404 Not found!
'// 判断用户请求的是否为 / 或 /index.html 首页// 判断用户请求的是否为 /about.html 关于页面if (url === '/' || url === '/index.html') {content = '首页
'} else if (url === '/about.html') {content = '关于页面
'}res.setHeader('Content-Type', 'text/html; charset=utf-8')res.end(content)
})server.listen(80, () => {console.log('server running at http://127.0.0.1')
})
module
对象,存储了和当前模块有关的信息module.exports
对象,将模块内的成员共享出去,供外界使用。导入自定义模块时,得到的就是 module.exports
指向的对象。exports
和 module.exports
指向同一个对象。最终共享的结果,以 module.exports
指向的对象为准。module
变量代表当前模块module
变量是一个对象,module.exports
是对外的接口module.exports
属性模块第一次加载后会被缓存,即多次调用 require()
不会导致模块的代码被执行多次,提高模块加载效率。
内置模块加载优先级最高。
加载自定义模块时,路径要以 ./
或 ../
开头,否则会作为内置模块或第三方模块加载。
导入自定义模块时,若省略文件扩展名,则 Node.js 会按顺序尝试加载文件:
.js
扩展名加载.json
扩展名加载.node
扩展名加载/node_modules
文件夹中加载第三方模块。例如,假设在 C:\Users\bruce\project\foo.js
文件里调用了 require('tools')
,则 Node.js 会按以下顺序查找:
C:\Users\bruce\project\node_modules\tools
C:\Users\bruce\node_modules\tools
C:\Users\node_modules\tools
C:\node_modules\tools
当把目录作为模块标识符进行加载的时候,有三种加载方式:
package.json
的文件,并寻找 main
属性,作为 require()
加载的入口package.json
文件,或者 main
入口不存在或无法解析,则 Node.js 将会试图加载目录下的 index.js
文件。