var fs = require("fs"),
i;
for(i in fs){
console.log(i);
}
var fs = require("fs");
fs.open(filename,flags,[mode],callback);
//同步打开文件
var fs = openSync(filename,flags,[mode]);
function(err , data){
//err为读取文件失败时,触发的错误对象
//data为回调函数的可用数据。
//在open的回调函数中,data是一个整数值,代表打开文件时返回的文件描述符(文件句柄)。
//每一个文件,都有唯一的文件描述符(句柄)。
}
| 属性 | 意义 |
| [code]r[/code] | 以【只读】的方式打开文件. 当文件不存在时产生异常 |
| [code]r+[/code] | 以【读写】的方式打开文件. 当文件不存在时产生异常 |
| [code]rs[/code] | 同步模式下,以【只读】的方式打开文件. 指令绕过操作系统的本地文件系统缓存。该功能主要用于打开 NFS 挂载的文件, 因为它可以让你跳过默认使用的过时本地缓存. 但这实际上非常影响 I/O 操作的性能, 因此除非你确实有这样的需求, 否则请不要使用该标志。注意: 这并不意味着 fs.open() 变成了一个同步阻塞的请求. 如果你想要一个同步阻塞的请求你应该使用 fs.openSync()。 |
| [code]rs[/code] | 同步模式下,以【只读】的方式打开文件. 指令绕过操作系统的本地文件系统缓存。该功能主要用于打开 NFS 挂载的文件, 因为它可以让你跳过默认使用的过时本地缓存. 但这实际上非常影响 I/O 操作的性能, 因此除非你确实有这样的需求, 否则请不要使用该标志。注意: 这并不意味着 fs.open() 变成了一个同步阻塞的请求. 如果你想要一个同步阻塞的请求你应该使用 fs.openSync()。 |
| [code]rs+[/code] | 同步模式下, 以【读写】的方式打开文件. 请谨慎使用该方式, 详细请查看 ‘rs' 的注释. |
| [code]w[/code] | 以【只写】的形式打开文件. 文件会被创建 (如果文件不存在) 或者覆盖 (如果存在). |
| [code]wx[/code] | 作用与”w”类似,区别是如果文件存在则操作会失败(必须去创建一个新的文件才行) |
| [code]w+[/code] | 以【读写】的方式打开文件. 文件会被创建 (如果文件不存在) 或者覆盖 (如果存在). |
| [code]wx+[/code] | 作用与”w+”类似,区别是如果文件存在则操作会失败(必须去创建一个新的文件才行) |
| [code]a[/code] | 以【附加】的形式打开文件,即新写入的数据会附加在原来的文件内容之后. 如果文件不存在则会默认创建. |
| [code]ax[/code] | 作用与”a”类似,区别是如果文件存在则操作会失败(必须去创建一个新的文件才行) |
| [code]a+[/code] | 以【读取】和【附加】的形式打开文件. 如果文件不存在则会默认创建. |
| [code]ax+[/code] | 作用与”a+”类型,区别是如果文件存在则操作会失败(必须去创建一个新的文件才行 |
var fs = require("fs"),
i;
fs.open("fs.txt","r+",function(err,fd){
console.log(err);
console.log(fd);
//open一个文件成之后,返回的是一个文件的描述符,是一个数字
});
var binding = process.binding('fs'),
FSReqWrap = binding.FSReqWrap;
//binding是C++与nodejs的接口,
//FSReqWrap是C++实现的一个方法。具体完成什么功能,不知
function modeNum(m, def) {
//验证mode所用的,把m转换成数字
//如果是数字,则直接返回,
//如果是字符串,则转换成8禁止数字,
//如果第二个参数存在,则把第二个参数转换为数字,
//如果不存在,则返回undefined
if (util.isNumber(m))
return m;
if (util.isString(m))
return parseInt(m, 8);
if (def)
return modeNum(def);
return undefined;
}
function makeCallback(cb) {
if (util.isNullOrUndefined(cb)) {
//如果传入的值为null或者undefined,则返回异常处理函数
return rethrow();
//rethrow是一个异常处理函数,这里不涉及
}
if (!util.isFunction(cb)) {
//如果传入的值,不是function类型,则抛出一个类型错误
throw new TypeError('callback must be a function');
}
//否则,形成一个闭包,用于改变回调函数的内部指向
//当该诶不上下文时,则内部的this指向顶级作用域
return function() {
return cb.apply(null, arguments);
};
}
function nullCheck(path, callback) {
//判断path是否合法,就是不能再path中,包含空格符。
if (('' + path).indexOf('u0027) !== -1) {
var er = new Error('Path must be a string without null bytes.');
if (!callback)
throw er;
//如果不合法,则传入err,并执行回调函数
process.nextTick(function() {
callback(er);
});
return false;
}
return true;
}
fs.open = function(path, flags, mode, callback) {
//使用传入的最后一个参数,生成一个有闭包的函数,作为回调函数
callback = makeCallback(arguments[arguments.length - 1]);
mode = modeNum(mode, 438 /*=0666*/);
//设置mode为八进制的数值,如果没有设置,则默认设置为438,八进制=0666
//如果path路径不合法,则直接执行回调,并把错误对象传入回调函数,
//结束
if (!nullCheck(path, callback)) return;
//否则,实例化一个FSReqWrap对象,并给该对象绑定一个oncomplete方法。
var req = new FSReqWrap();
req.oncomplete = callback;
//使用C++公开的接口,执行打开文件的操作。
binding.open(pathModule._makeLong(path),
stringToFlags(flags),
mode,
req);
};
var fs = require("fs");
fs.open("fs.txt","r",function(err,fd){
//有一点需要注意,close文件时,需要文件描述符,也就是open成功时,返回的数字。
//即,需要fd。
fs.close(fd,function(err){
//close的回调函数,该回调只支持一个参数,就是当发生错误时的错误对象
});
//关于close的同步执行方法closeSync,这里就不举例了
});
fs.close = function(fd, callback) {
var req = new FSReqWrap();
req.oncomplete = makeCallback(callback);
//创建一个实例,并把回调函数,绑定到实例中的oncomplete属性上
//调用C++中的close方法。
binding.close(fd, req);
};
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有