1

我试图让我的代码使用显然是非标准设置的方式优化到单个文件,我正在努力理解所有不同路径的含义。

想象一下,我正在制作包含r almond 的 requirejs 命令行工具的变体。所以我希望能够使用工具中包含的杏仁包裹杏仁。

我的目录结构

someAppFolder
|
+--main.js

在相关文件夹中

myRPlusAlmondBuilder
|
+--myRPlusAlmonBuilder.js
|
+--node_modules
   |
   +--almond
   |  |
   |  +--almond.js
   |
   +--requirejs
      |
      ...

所以,我希望myRPlusAlmondBuilder能够main.js像这样构建一个单一的 JS 包

cd myRPlusAlmondBuilder
node myRPlusAlmondBuilder.js someAppFolder/main.js

这是一个简单的 myRPlusAlmondBuilder.js

var requirejs = require('requirejs');
var path = require('path');

var filename = process.argv[2];                
var dirname = path.dirname(filename);          
var barename = path.basename(filename, ".js"); 

var config = {
  baseUrl: dirname,
  name: "node_modules/almond/almond",
  include: barename,
  insertRequire: [barename],
  out:     "out.js",
  wrap:    true,
};

// show the values 
console.log(JSON.stringify(config, undefined, "  "));

requirejs.optimize(config, function() {
  console.log("result is in:", config.out);
}, function(err) {
  console.error(err);
});

像这样称呼它

cd myRPlusAlmondBuilder.js
node myRPlusAlmondBuilder.js /Users/gregg/temp/delme-requirejs/someAppFolder/main.js

但我明白了

{
  "baseUrl": "/Users/gregg/temp/delme-requirejs/someAppFolder",
  "name": "node_modules/almond/almond",
  "include": "main",
  "insertRequire": [
    "main"
  ],
  "out": "out.js",
  "wrap": true
}
{ [Error: Error: ERROR: module path does not exist: /Users/gregg/temp/delme-requirejs/someAppFolder/node_modules/almond/almond.js for module named: node_modules/almond/almond. Path is relative to: /Users/gregg/temp/delme-requirejs/myRPlusAlmondBuilder

尝试所有其他值name都失败

// dot in front 
name: "./node_modules/almond/almond",

// .js on end
name: "node_modules/almond/almond.js",

// .dot in front and .js on end
name: "./node_modules/almond/almond.js",

// absolute path to almond.js with .js
name: path.join(__dirname, "node_modules/almond/almond.js"),

// absolute path to almond.js without .js
name: path.join(__dirname, "node_modules/almond/almond"),

带有“.js”的那些得到

[Error: Error: ENOENT, no such file or directory '/Users/gregg/temp/delme-requirejs/someAppFolder/node_modules/almond/almond.js'
at Error (native)
]

具有完整路径的那些得到

[Error: Error: ENOENT, no such file or directory '/Users/gregg/temp/delme-requirejs/someAppFolder//Users/gregg/temp/delme-requirejs/myRPlusAlmondBuilder/node_modules/almond/almond.js'
at Error (native)
]

使用从 main.js 到 almond 的相对路径有效

name: path.relative(dirname, path.join(__dirname, "node_modules/almond/almond.js")),

但是如果工具在C:/somefolder/myRPlusAlmond和文件在D:/someAppFolder/main.js

有没有办法对杏仁使用绝对路径?

4

1 回答 1

0

我找到了一种方法是为杏仁添加路径

var config = {
  baseUrl: dirname,
  name: "__dontclash_almond__/almond",
  include: barename,
  insertRequire: [barename],
  out:     "out.js",
  wrap:    true,
  paths: {
    __dontclash_almond__: path.join(__dirname, "node_modules/almond"),
  }.
};

似乎有点 hacky,因为我必须希望我不会与用户选择的名称发生冲突。当然不太可能发生冲突

于 2016-05-06T16:22:32.063 回答