技术解答js中的全局对象和全局变量以及文件系统
node全局对象是js中的一个对象,该对象又称为为全局对象。在客户端中,该对象为whindow,由this进行指向ode中的全局对象为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\test PS 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.js hello world! C:\Program Files\nodejs\node.exe0C:\Program Files\nodejs\node.exe,C:\Users\mingm\Desktop\test\main.js C:\Users\mingm\Desktop\test\main.js1C:\Program Files\nodejs\node.exe,C:\Users\mingm\Desktop\test\main.js C:\Program Files\nodejs\node.exe win32 PS 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.js true PS 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>
读取文件
在异步的情况下读取文件
参数 http://nodejs.cn/api/fs.html#...
使用的fs.read http://nodejs.cn/api/fs.html#...
var fs = require('fs'); var buf = new Buffer.alloc(1024); // 创建一个缓冲区 console.log('准备打开已存在的文件'); fs.open('input.txt', 'r+', (err, fd) => { if (err) { 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 (buyes > 0) { console.log(buf.slice(0, bytes).toString()); } }); });
PS C:\Users\mingm\Desktop\test> node main.js 准备写入文件 数据写入成功! ----我是分割线---- 开始读取写入的数据 异步读取数据为我是异步写入的内容 PS C:\Users\mingm\Desktop\test>
Buffer.slice http://nodejs.cn/api/buffer.html
返回一个指向相同原始内存的新建的 Buffer
PS 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('文件关闭成功'); }); }); });
截取文件
在异步的模式下截取文件
fs.ftruncate(fd[, len], callback)
http://nodejs.cn/api/fs.html#...
var fs = require('fs'); var buf = new Buffer.alloc(1024); console.log('准备打开文件!'); fs.open('input.txt', 'r+', (err, fd) => { if (err) { return console.error(err); }; console.log('文件打开成功!'); console.log('截取了10字节后的文件内容。'); // 截取文件 fs.ftruncate(fd, 10, (err) => { if (err) { 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) => { console.log(err); }); console.log('文件关闭成功!'); }); }); });
PS C:\Users\mingm\Desktop\test> node main.js 准备打开文件! 文件打开成功! 截取了10字节后的文件内容。 文件截取成功 读取相同的文件 我是异� 文件关闭成功! null PS C:\Users\mingm\Desktop\test>
删除文件
PS C:\Users\mingm\Desktop\test> node main.js 准备删除文件! 文件删除成功! PS C:\Users\mingm\Desktop\test>
var fs = require('fs'); console.log('准备删除文件!') fs.unlink('input.txt', (err) => { if (err) { return console.log(err); }; console.log('文件删除成功!'); });
创建目录
PS C:\Users\mingm\Desktop\test> node main.js 创建目录 ./tmp/test { [Error: ENOENT: no such file or directory, mkdir 'C:\Users\mingm\Desktop\test\tmp\test'] errno: -4058, code: 'ENOENT', syscall: 'mkdir', path: 'C:\\Users\\mingm\\Desktop\\test\\tmp\\test' } PS C:\Users\mingm\Desktop\test>
var fs = require('fs'); console.log('创建目录 ./tmp/test'); fs.mkdir('./tmp/test', (err) => { if (err) { return console.log(err); }; console.log('目录创建成功!'); });
读取目录
forEach方法没有找到一个 官方文档,貌似目前找不到
PS C:\Users\mingm\Desktop\test> node main.js 查看 /tmp 目录 { [Error: ENOENT: no such file or directory, scandir 'C:\Users\mingm\Desktop\test\tmp'] errno: -4058, code: 'ENOENT', syscall: 'scandir', path: 'C:\\Users\\mingm\\Desktop\\test\\tmp' } PS C:\Users\mingm\Desktop\test>
var fs = require('fs'); console.log('查看 /tmp 目录'); fs.readdir('./tmp/', (err, files) => { if (err) { return console.log(err); }; files.forEach((file) => { // 这个方法目前没有找到,联系到客户端的方法,貌似是合并的意思 console.log( file ); }); });
相关文章:
相关视频:
以上是技术解答js中的全局对象和全局变量以及文件系统的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

如何使用WebSocket和JavaScript实现在线语音识别系统引言:随着科技的不断发展,语音识别技术已经成为了人工智能领域的重要组成部分。而基于WebSocket和JavaScript实现的在线语音识别系统,具备了低延迟、实时性和跨平台的特点,成为了一种被广泛应用的解决方案。本文将介绍如何使用WebSocket和JavaScript来实现在线语音识别系

WebSocket与JavaScript:实现实时监控系统的关键技术引言:随着互联网技术的快速发展,实时监控系统在各个领域中得到了广泛的应用。而实现实时监控的关键技术之一就是WebSocket与JavaScript的结合使用。本文将介绍WebSocket与JavaScript在实时监控系统中的应用,并给出代码示例,详细解释其实现原理。一、WebSocket技

如何利用JavaScript和WebSocket实现实时在线点餐系统介绍:随着互联网的普及和技术的进步,越来越多的餐厅开始提供在线点餐服务。为了实现实时在线点餐系统,我们可以利用JavaScript和WebSocket技术。WebSocket是一种基于TCP协议的全双工通信协议,可以实现客户端与服务器的实时双向通信。在实时在线点餐系统中,当用户选择菜品并下单

如何使用WebSocket和JavaScript实现在线预约系统在当今数字化的时代,越来越多的业务和服务都需要提供在线预约功能。而实现一个高效、实时的在线预约系统是至关重要的。本文将介绍如何使用WebSocket和JavaScript来实现一个在线预约系统,并提供具体的代码示例。一、什么是WebSocketWebSocket是一种在单个TCP连接上进行全双工

JavaScript和WebSocket:打造高效的实时天气预报系统引言:如今,天气预报的准确性对于日常生活以及决策制定具有重要意义。随着技术的发展,我们可以通过实时获取天气数据来提供更准确可靠的天气预报。在本文中,我们将学习如何使用JavaScript和WebSocket技术,来构建一个高效的实时天气预报系统。本文将通过具体的代码示例来展示实现的过程。We

JavaScript教程:如何获取HTTP状态码,需要具体代码示例前言:在Web开发中,经常会涉及到与服务器进行数据交互的场景。在与服务器进行通信时,我们经常需要获取返回的HTTP状态码来判断操作是否成功,根据不同的状态码来进行相应的处理。本篇文章将教你如何使用JavaScript获取HTTP状态码,并提供一些实用的代码示例。使用XMLHttpRequest

用法:在JavaScript中,insertBefore()方法用于在DOM树中插入一个新的节点。这个方法需要两个参数:要插入的新节点和参考节点(即新节点将要被插入的位置的节点)。

JavaScript是一种广泛应用于Web开发的编程语言,而WebSocket则是一种用于实时通信的网络协议。结合二者的强大功能,我们可以打造一个高效的实时图像处理系统。本文将介绍如何利用JavaScript和WebSocket来实现这个系统,并提供具体的代码示例。首先,我们需要明确实时图像处理系统的需求和目标。假设我们有一个摄像头设备,可以采集实时的图像数
