我怎么写这个回到父2层去找文件?
fs.readFile(__dirname + 'foo.bar');
我怎么写这个回到父2层去找文件?
fs.readFile(__dirname + 'foo.bar');
当前回答
最简单的方法是使用path.resolve:
path.resolve(__dirname, '..', '..');
其他回答
最简单的方法是使用path.resolve:
path.resolve(__dirname, '..', '..');
你可以用不同的方法定位父文件夹下的文件,
const path = require('path');
const fs = require('fs');
// reads foo.bar file which is located in immediate parent folder.
fs.readFile(path.join(__dirname, '..', 'foo.bar');
// Method 1: reads foo.bar file which is located in 2 level back of the current folder.
path.join(__dirname, '..','..');
// Method 2: reads foo.bar file which is located in 2 level back of the current folder.
fs.readFile(path.normalize(__dirname + "/../../foo.bar"));
// Method 3: reads foo.bar file which is located in 2 level back of the current folder.
fs.readFile(__dirname + '/../../foo.bar');
// Method 4: reads foo.bar file which is located in 2 level back of the current folder.
fs.readFile(path.resolve(__dirname, '..', '..','foo.bar'));
如果另一个模块调用你的,你仍然想知道正在运行的主文件的位置,你可以使用@Jason的代码修改:
var path = require('path'),
__parentDir = path.dirname(process.mainModule.filename);
fs.readFile(__parentDir + '/foo.bar');
通过这种方式,您将获得实际运行的脚本的位置。
我知道这有点挑剔,但到目前为止,所有的答案都不太正确。
path.join()的目的是消除调用者知道使用哪个目录分隔符的需要(使代码与平台无关)。
从技术上讲,正确答案应该是这样的:
var path = require("path");
fs.readFile(path.join(__dirname, '..', '..', 'foo.bar'));
我本想把这句话作为对Alex Wayne的回答的评论,但还不够代表!
编辑:根据用户1767586的观察
这很好
path.join(__dirname + '/../client/index.html')
const path = require('path')
const fs = require('fs')
fs.readFile(path.join(__dirname + '/../client/index.html'))