FileSystem
文件 I/O 是由简单封装的标准 POSIX 函数提供的。 通过 require(‘fs’)使用该模块。 所有的方法都有异步和同步的形式。
异步形式始终以完成回调作为它最后一个参数。 传给完成回调的参数取决于具体方法,但第一个参数总是留给异常。 如果操作成功完成,则第一个参数会是 null或 undefined,如果操作失败,则第一个参数将是一个错误对象;
需要注意一点,异步操作无法通过try-catch来捕获异常
当使用同步形式时,任何异常都会被立即抛出。 可以使用 try/catch 来处理异常,或让它们往上冒泡。
nodejs fs
1 读取文件操作readFile(file,options,callback)
- file是要读取的文件的路径
- options
- encoding
| null //默认值是null,所以如果不指定编码方式,读取文件的结果默认返回的值是二进制数据,返回的结果会作为参数传递给callback回调函数 - flag
默认是 ‘r’
- encoding
- callback 回调函数又有两个参数,第一个参数是error对象,第二个参数是读取到的数据
- 如果读取文件成功,err返回null data返回读取到的文件数据;(如果字符编码未指定,则返回原始的buffer数据)
- 如果读取文件失败,err返回一个错误对象,data返回undefined;
- 注意读取文件的内容返回的结果要么是Buffer类型的数据,要么是字符串类型的数据
|
|
|
|
2 写入文件的操作writeFile(file,data,[option],callback)
- file可以是文件名或者文件描述
- data是异步地写入的数据内容,可以是一个string或者buffer
- option 编码格式,如果data是一个buffer,则默认encoding是utf-8
- callback 回调函数,该回调函数里面只有一个参数就是err错误处理对象,如果写入成功err返回null
看下面这个简单的例子
|
|
需要注意的是,我们只能写入字符串或者Buffer类型的数据,如果写入复杂数据类型
|
|
3 以上文件的读写都是异步进行的,不会阻塞程序的执行,同时我们在日常工作中通过服务器端的数据的读写也会经常用到这两个API
4 对于异步 的任务,很多时候,每个任务的执行先后顺序是无法控制的,那么如何去解决这个问题?
此时,如果需要异步任务按照我们的意愿顺序进行,那么则需要将形成异步嵌套,形成一个回调链