Node.js的fs模块中,关于fs.watch的疑问
迷茫
迷茫 2017-04-17 13:23:46
0
1
487

在学习Node.js的fs模块时候,有一个函数是fs.watch,用于监测文件目录是否有改变.然后编写了如下的测试代码:

var fs = require('fs');
var watch = './watch';
var done = './done';

fs.watch(watch, (err, file) => {
  if (file) {
    console.log(file);
    fs.rename(watch + '/' + file, done + '/' + file, (err) => {
      if (err) console.error(err);
    });
  }
});

这段程序是有问题的.假设我在watch目录下touch 1.txt, 则实际上会抛出异常:

lgtdeMacBook-Pro:test lgt$ node test.js
1.txt
1.txt
{ [Error: ENOENT: no such file or directory, rename './watch/1.txt' -> './done/1.txt']
  errno: -2,
  code: 'ENOENT',
  syscall: 'rename',
  path: './watch/1.txt',
  dest: './done/1.txt' }

这里很显然的告诉我们,1.txt居然出现了两次.第一次我们成功的通过rename从watch目录转移到done目录,从而导致第二次rename时候1.txt文件已经不存在.

疑问:

  1. 这里1.txt为什么会出现两次?

迷茫
迷茫

业精于勤,荒于嬉;行成于思,毁于随。

全部回覆(1)
Ty80

因為你rename的時候又觸發了一次

看fs.watch的文檔,回呼簽名不是(err, file) 而是(event, file),第一個參數告訴你發生了什麼事情

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!