node全局对象
js中一个对象,该对象为全局对象。
在客户端中,该对象为whindow,由this进行指向
node中的全局对象为global,所有的全局变量,除了自己以外都是global对象的属性
全局对象和全局变量
全局变量是全局对象的宿主
_filename
表示当前正在执行的脚本名,将会输出文件位置所在的绝对路径。
如果在模块中,返回的是模块文件的路径。
PS C:\Users\mingm\Desktop\test> node main.js C:\Users\mingm\Desktop\test\main.js PS C:\Users\mingm\Desktop\test>
// 输出全局变量 __filename的值console.log(__filename);
__dirname
表示当前执行脚本所在的目录
PS C:\Users\mingm\Desktop\test> node main.js C:\Users\mingm\Desktop\testPS C:\Users\mingm\Desktop\test>
console.log(__dirname);
setTimeout
function printHello() { console.log('hello word'); };// 两秒后执行以上函数setTimeout(printHello, 2000); // 该函数返回一个代表定时器的句柄值
function printHello() { console.log('hello word'); };// 两秒后执行以上函数setTimeout(printHello, 2000); // 该函数返回一个代表定时器的句柄值
clearTimeout
停止一个计时器
settlnterval
一个计时器会不断的调用,返回的是一个代表定时器的句柄值
function printHello() { console.log('hello word!'); };// 每两秒后循环执行以上函数setInterval(printHello, 2000);
PS C:\Users\mingm\Desktop\test> node main.js hello word! hello word! hello word! hello word! hello word! hello word! hello word! hello word! hello word!
process
一个全局变量,即global对象的属性
用于描述当前node进程状态的对象。
process.on('exit', (code) => { // 下方代码不会执行 setTimeout(() => {console.log('该代码不会执行');}, 0); console.log('退出码为', code); });console.log('程序执行结束');
PS C:\Users\mingm\Desktop\test> node main.js 程序执行结束 退出码为 0 PS C:\Users\mingm\Desktop\test>
一个示例文件
// 输出到终端process.stdout.write('hello world!' + '\n'); // 创建一个写入流,通过写入流,输出到终端// 通过参数读取process.argv.forEach((val, index, array) => {console.log(val + index + array)});// 获取执行路径console.log(process.execPath);// 平台信息console.log(process.platform);
PS C:\Users\mingm\Desktop\test> node main.jshello world!C:\Program Files\nodejs\node.exe0C:\Program Files\nodejs\node.exe,C:\Users\mingm\Desktop\test\main.jsC:\Users\mingm\Desktop\test\main.js1C:\Program Files\nodejs\node.exe,C:\Users\mingm\Desktop\test\main.jsC:\Program Files\nodejs\node.exewin32PS C:\Users\mingm\Desktop\test>
PS C:\Users\mingm\Desktop\test> node main.js{ rss: 18874368, heapTotal: 6066176, heapUsed: 3677376, external: 8272 }PS C:\Users\mingm\Desktop\test>
// 输出内存使用情况console.log(process.memoryUsage());
node文件系统
node提供一组类似unix的标准文件操作api
异步和同步
异步的方法后面会有一个回调函数
貌似回调多了以后会产生回调地狱
var fs = require('fs');// 异步读取fs.readFile('input.txt', (err, data) => { err?console.error(err):true; console.log('异步读取' + data.toString()); });
PS C:\Users\mingm\Desktop\test> node main.js 异步读取33333333333333333333333333333333333333333 PS C:\Users\mingm\Desktop\test>
ps 减少异步,让世界更美好一点(o)/
建议回调使用箭头函数,要不然很容易产生回调地狱,让人抓狂
打开文件
// 打开input.txt文件进行读写var fs = require('fs');// 异步打开文件console.log('准备打开文件!'); fs.open('input.txt', 'r+', (err, fd) => {err?console.log(err):console.log('文件打开成功!');});
PS C:\Users\mingm\Desktop\test> node main.js 准备打开文件! 文件打开成功!
获取文件信息
fs模块下的stat方法
判断是否是文件
var fs = require('fs'); fs.stat('input.txt', (err, stats) => {console.log(stats.isFile());});
PS C:\Users\mingm\Desktop\test> node main.jstruePS C:\Users\mingm\Desktop\test>
var fs = require('fs');console.log('准备打开文件!'); fs.stat('input.txt', (err, stats) => {err?console.log(err):console.log(stats); console.log('读取文件信息成功!'); // 检测文件类型 console.log(stats.ifFile()); console.log(stats.isDirectory()); });
PS C:\Users\mingm\Desktop\test> node main.js准备打开文件!Stats { dev: 982976588, mode: 33206, nlink: 1, uid: 0, gid: 0, rdev: 0, blksize: undefined, ino: 12103423998567884, size: 41, blocks: undefined, atimeMs: 1532607165034.9072, mtimeMs: 1532606924599.2798, ctimeMs: 1532606924599.2798, birthtimeMs: 1532606914067.3428, atime: 2018-07-26T12:12:45.035Z, mtime: 2018-07-26T12:08:44.599Z, ctime: 2018-07-26T12:08:44.599Z, birthtime: 2018-07-26T12:08:34.067Z } 读取文件信息成功!C:\Users\mingm\Desktop\test\main.js:7 console.log(stats.ifFile()); ^TypeError: stats.ifFile is not a function at fs.stat (C:\Users\mingm\Desktop\test\main.js:7:20) at FSReqWrap.oncomplete (fs.js:159:5)PS C:\Users\mingm\Desktop\test>
写入文件
var fs = require('fs');console.log('准备写入文件'); fs.writeFile('input.txt', '我是异步写入的内容', (err) => { err?console.log(err):false; console.log('数据写入成功!'); console.log('----我是分割线----'); console.log('开始读取写入的数据'); fs.readFile('input.txt', (err, data) => { err?console.log(err):false; console.log('异步读取数据为' + data.toString()); }); });
PS C:\Users\mingm\Desktop\test> node main.js 准备写入文件 数据写入成功! ----我是分割线---- 开始读取写入的数据 异步读取数据为我是异步写入的内容 PS C:\Users\mingm\Desktop\test>
读取文件
在异步的情况下读取文件 Buffer.slice http://nodejs.cn/api/buffer.html 在异步的模式下关闭文件
参数 http://nodejs.cn/api/fs.html#fs_event_open_1
使用的fs.read PS C:\Users\mingm\Desktop\test> node main.js
准备写入文件
数据写入成功!
----我是分割线----
开始读取写入的数据
异步读取数据为我是异步写入的内容
PS C:\Users\mingm\Desktop\test>
返回一个指向相同原始内存的新建的 BufferPS C:\Users\mingm\Desktop\test> node main.js
准备打开已存在的文件
文件打开成功
准备读取文件
27字节被读取
我是异步写入的内容
PS C:\Users\mingm\Desktop\test>
var fs = require('fs');var buf = new Buffer.alloc(1024); // 创建一个缓冲区console.log('准备打开已存在的文件');
fs.open('input.txt', 'r+', (err, fd) => { if (err) { return console.log(err);
}; console.log('文件打开成功'); console.log('准备读取文件');
fs.read(fd, buf, 0, buf.length, 0, (err, bytes) => { if (err) { console.log(err);
}; console.log(bytes + '字节被读取'); // 输出读取的字节
if (bytes > 0) { console.log(buf.slice(0, bytes).toString());
}
});
});
关闭文件
PS C:\Users\mingm\Desktop\test> node main.js
准备打开文件!
文件打开成功!
准备读取文件!
我是异步写入的内容
文件关闭成功
PS C:\Users\mingm\Desktop\test>
var fs = require('fs');var buf = new Buffer.alloc(1024);console.log('准备打开文件!');
fs.open('input.txt', 'r+', (err, fd) => { if (err) { return console.log(err);
}; console.log('文件打开成功!'); console.log('准备读取文件!');
fs.read(fd, buf, 0, buf.length, 0, (err, bytes) => { if (err) { console.log(err);
}; // 输出能读取的字节
if(bytes > 0) { console.log(buf.slice(0,bytes).toString());
}; // 关闭文件
fs.close(fd, (err) => { if(err) { console.log(err);
}; console.log('文件关闭成功');
});
});
});
截取文件
共同學習,寫下你的評論
評論加載中...
作者其他優質文章