Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/414.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript node.js获取相对于文件的项目/src路径_Javascript_Node.js - Fatal编程技术网

Javascript node.js获取相对于文件的项目/src路径

Javascript node.js获取相对于文件的项目/src路径,javascript,node.js,Javascript,Node.js,在node.js项目中,我使用log4js,我希望我的日志具有添加日志记录的文件名。所以我使用了_文件名,但它提供了绝对路径 var logger = log4js.getLogger(__filename) 所以它给了我这样的日志: [1999-01-01 00:00:00] [DEBUG] /Users/whatever/myproject/src/services/users something happened 但是我希望路径是相对于我的project/src文件夹的。像这样: [1

在node.js项目中,我使用log4js,我希望我的日志具有添加日志记录的文件名。所以我使用了_文件名,但它提供了绝对路径

var logger = log4js.getLogger(__filename)
所以它给了我这样的日志:

[1999-01-01 00:00:00] [DEBUG] /Users/whatever/myproject/src/services/users something happened
但是我希望路径是相对于我的project/src文件夹的。像这样:

[1999-01-01 00:00:00] [DEBUG] services/users something happened
实现这一目标的最佳方式是什么

var root = '/Users/whatever/myproject/src/';

var filename = __filename.replace(root, '');
字符串
replace
将替换第一个出现的字符串,因此即使您有多次
根模式,它也只会被替换一次。

您可以使用:

您可以与
\uuuu dirname
\uuuu filename
一起使用:

var path = require('path');
var here = path.basename(__dirname) + '/' + path.basename(__filename, '.js');
或者,如果您喜欢正则表达式,可以执行以下操作:

var here = /\/([^/]+\/[^/]+)\.js$/.exec(__filename)[1];

谢谢你的建议!不幸的是,它只适用于两个级别,所以如果我有类似“services/external/api”的东西,它将不会有帮助。谢谢,这就是我想要的。但我决定只使用显式log4js.getLogger('services/user'),因为使用path需要使用require('path')
var here = /\/([^/]+\/[^/]+)\.js$/.exec(__filename)[1];