fs.FSWatcher
fs.FSWatcher类 继承了 EventEmitter,用于监视文件变化,调用 fs.watch 后返回一个 fs.FSWatcher 实例,每当指定监视的文件被修改时,实例会触发事件调用回调函数
fs.watch('./tmp', (eventType, filename) => { if (filename) { console.log(filename); } });
fs.watch()
fs.watch(filename[, options][, listener])
监视文件变化,返回 fs.FSWatcher 实例
1.filename:文件或文件夹路径
2.options
- encoding
- recursive:默认值 false,应该监视所有子目录,还是仅监视当前目录,仅在 macOS 和 Windows 上支持
- persistent:默认值 true,指示如果文件已正被监视,进程是否应继续运行
- listener(eventType, filename):文件变化回调函数
eventType 主要是 rename
和 change
,在大多数平台上,文件在目录中出现或消失时触发 'rename' 事件,在 Windows 上,如果监视的目录被移动或重命名,则不会触发任何事件,当监视的目录被删除时,则报告 EPERM
错误
fs.watch('./', { recursive: true }, (eventType, filename) => { console.log(eventType, filename); });
fs.watchFile()
fs.watchFile(filename[, options], listener)
用于监视文件变化
1.filename
2.options
- biginit:默认值 false,指定回调 stat 中的数值是否为 biginit 类型
- persistent:默认值 true,当文件正在被监视时,进程是否应该继续运行
- interval:默认值 5007,用来指定轮询频率(ms)
3.listener(currentStats, previousStats):listener 有两个参数,当前的 stat 对象和之前的 stat 对象
要在修改文件时收到通知,则需要比较 curr.mtime
和 prev.mtime
const fs = require('fs'); fs.watchFile('./test.txt', { interval: 100 }, (curr, prev) => { console.log('当前的最近修改时间是: ' + curr.mtime); console.log('之前的最近修改时间是: ' + prev.mtime); }); const tid = setInterval(() => { fs.appendFile('./test.txt', 'Hello, world!\n', err => { if (err) throw err; console.log('文件修改完成'); }); }, 300); setTimeout(() => { clearInterval(tid); fs.unwatchFile('./test.txt'); }, 2000);
fs.watch() 与 fs.watchFile()
因为 fs.watchFile() 使用轮训方式检测文件变化,如果不设置 interval
或者设置较高的值会发现文件变化的监视有延迟
而 fs.watch() 监听操作系统提供的事件,而且可以监视目录变化,使用 fs.watch() 比 fs.watchFile() 更高效,平常应尽可能使用 fs.watch() 代替 fs.watchFile()
当然 fs.watch() 依赖操作系统的实现,在不同平台上表现会有差异
- Linux 操作系统使用 inotify
- 在 macOS 系统使用 FSEvents
- 在 windows 系统使用 ReadDirectoryChangesW
fs.unwatchFile
fs.unwatchFile(filename[, listener])
停止监视 filename 的变化,如果指定了 listener,则仅移除此特定监听器,否则将移除所有监听器,从而停止监视 filename
fs.unwatchFile('./test.txt');
社区选择
fs.watchFile() 性能问题,fs.watch() 平台不一致等两个方法都有不尽如人意的地方
Node.js fs.watch
:
MacOS 有时候不提供 filename
在部分场景不触发修改事件(MacOS Sublime)
经常一次修改两次触发事件
大部分文件变化 eventType 都是 rename.
未提供简单的监视文件树方式
Node.js fs.watchFile
:
事件处理问题和 fs.watch 一样烂
没有嵌套监听
CPU 消耗大
https://www.npmjs.com/package/chokidar
日常在监视文件变化可以选择社区的优秀方案
- node-watch
- chokidar
const chokidar = require('chokidar'); // One-liner for current directory chokidar.watch('.').on('all', (event, path) => { console.log(event, path); });
// Initialize watcher. const watcher = chokidar.watch('file, dir, glob, or array', { ignored: /(^|[\/\\])\../, // ignore dotfiles persistent: true }); // Something to use when events are received. const log = console.log.bind(console); // Add event listeners. watcher .on('add', path => log(`File ${path} has been added`)) .on('change', path => log(`File ${path} has been changed`)) .on('unlink', path => log(`File ${path} has been removed`)); // More possible events. watcher .on('addDir', path => log(`Directory ${path} has been added`)) .on('unlinkDir', path => log(`Directory ${path} has been removed`)) .on('error', error => log(`Watcher error: ${error}`)) .on('ready', () => log('Initial scan complete. Ready for changes')) .on('raw', (event, path, details) => { // internal log('Raw event info:', event, path, details); });
以上就是node.js 如何监视文件变化的详细内容,更多关于node.js 监视文件的资料请关注其它相关文章!
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]