0

首先是一些代码:

我运行的 r.js 启动文件r.js.cmd -o static/js/boot.js

({
    baseUrl: './',
    preserveLicenseComments: false,
    name: 'boot',
    stubModules: ['text'],
    mainConfigFile: './requirejs/config.js',
    out: 'build.min.js',
    //paths: {
    //    'text': 'plugins/requirejs.text'
    //},
})

然后插件在控制台中抛出异常:

Error: Error: Loader plugin did not call the load callback in the build:
text:
    text!langJSON: Error: ENOENT, no such file or directory 'C:\web\lang\main'
    text!/web/downloads/links.json: Error: ENOENT, no such file or directory 'C:\web\downloads\links.json'

有人可以回答我为什么 r.js 评估“文本”插件,尽管在构建配置文件属性中使用“stubModules”参数?

我以前读过这篇文章:

  1. 如何防止 Require.js 优化器在优化文件中包含文本插件?
  2. 内联 require.js 文本!使用咕噜声

提前致谢。

4

1 回答 1

1

stubModules不会告诉优化器跳过通过text插件加载的所有内容。它只是告诉优化器在最终包中用以下代码替换插件:

define('text',{load: function(id){throw new Error("Dynamic load not allowed: " + id);}});

如果您正在创建一个包含代码所需的每个模块的包,这将非常有用。如果是这种情况,那么通过加载的所有模块text已经在包中,因此在包中包含text插件的代码是没有意义的,因为它不会被使用。(在这种情况下,插件在构建时使用,但不在运行时使用。)

你得到的错误是因为优化器仍然试图在你的包中包含那些通过 加载的模块text,但它没有找到文件。

如果您想要做的是从捆绑包中排除通过 加载的所有内容,text您可以做的一件事是paths在构建配置中添加一个,将这些模块列为empty:. 例如:

paths: {
    'web/downloads/links.json': 'empty:',
    ...
}

但是你需要text在运行时使用插件来加载文本,所以你应该删除stubModules.

于 2016-05-05T16:52:45.903 回答