方法说明:
以异步的方式打开文件。
在POSIX系统中,path被认为是默认存在的(即使该路径下的文件是不存在的)
flag标识 可能 或 可能不在网络文件系统下运行。
语法:
fs.open(path, flags, [mode], [callback(err,fd)])
由于该方法属于fs模块,使用前需要引入fs模块(var fs= require(“fs”) )
接收参数:
path 文件路径
flags 可以是以下的值
'r' - 以读取模式打开文件。 'r+' - 以读写模式打开文件。 'rs' - 使用同步模式打开并读取文件。指示操作系统忽略本地文件系统缓存。 'rs+' - 以同步的方式打开,读取 并 写入文件。 注意:这不是让fs.open变成同步模式的阻塞操作。如果想要同步模式请使用fs.openSync()。 'w' - 以读取模式打开文件,如果文件不存在则创建 'wx' - 和 ' w ' 模式一样,如果文件存在则返回失败 'w+' - 以读写模式打开文件,如果文件不存在则创建 'wx+' - 和 ' w+ ' 模式一样,如果文件存在则返回失败 'a' - 以追加模式打开文件,如果文件不存在则创建 'ax' - 和 ' a ' 模式一样,如果文件存在则返回失败 'a+' - 以读取追加模式打开文件,如果文件不存在则创建 'ax+' - 和 ' a+ ' 模式一样,如果文件存在则返回失败 mode 用于创建文件时给文件制定权限,默认0666
callback 回调函数会传递一个文件描述符 fd ,和一个异常err
例子:
var fs = require('fs'); fs.open('/path/demo1.txt', 'a', function (err, fd) { if (err) { throw err; } fs.futimes(fd, 1388648322, 1388648322, function (err) { if (err) { throw err; } console.log('futimes complete'); fs.close(fd, function () { console.log('Done'); }); }); });
源码:
fs.open = function(path, flags, mode, callback) { callback = makeCallback(arguments[arguments.length - 1]); mode = modeNum(mode, 438 /*=0666*/); if (!nullCheck(path, callback)) return; binding.open(pathModule._makeLong(path), stringToFlags(flags), mode, callback); };