Browserify为模块分配相对路径,而不是绝对路径



给定此文件树:

src
- main.js
ui
- foo.js
- bar.js

该命令生成标识符已设置为绝对模块路径的模块:

browserify ./src/**/*.js -o ./dist/bundle.js --full-paths

结果模块id:

"/Users/rikschennink/.../src/ui/foo.js"

有没有办法使这些模块路径相对?如果我省略了--full-paths命令,我只剩下索引作为模块标识符,所以这不起作用。

我想捆绑所有模块,但仍然可以用这样的按需路径引用它们。

var module = require('/ui/foo');

我知道我可以别名模块,但这需要手动别名每个模块,这不是一个真正可行的解决方案。


我使用了一个JavaScript函数来替换输出流中的绝对路径。你可以在这里找到它:https://github.com/rikschennink/conditioner-boilerplate-browserify/blob/master/browserify.js

我只需使用sed为我修复

browserify -r ./src/ui/bar -r ./src/main ./src/**/*.js --full-paths | sed "s|$PWD/src||g" > ./dist/bundle.js

然后生成的最后一行是

},{}]},{},["/main.js","/ui/bar.js","/ui/ui.js"]);

正如你想要

最新更新