内联 require() 在 requirejs 中工作,但不适用于优化的 almond 构建

2023-12-20

正如标题所示,我的内联 require 调用在非优化的 requirejs 运行中工作,但在使用 grunt 和 almondjs 构建时不起作用。

Uncaught Error: undefined missing views/some/view

任何文件的顶部可能是:

define(
['jquery', 'app'],
function($, App) {

然后根据业务逻辑,我希望能够需要另一个文件

require(['views/some/view'], function(SomeView){
     console.log(SomeView);
});

我也尝试了替代语法:

var SomeView= require('views/some/view');

这一切都可以使用未构建的 requirejs 版本进行。但当我用 grunt 和 almond 构建它时,它再次失败

    requirejs: {
        compile: {
            options: {
                name: "../components/almond/almond", 
                baseUrl: "src",
                mainConfigFile: "./require.config.js",
                include: ['main'], 
                insertRequire: ['main'], // Add a require step in at the end for the main module.
                wrap: true, // Wrap everything up in a closure
                generateSourceMaps: true, // Experimental
                preserveLicenseComments: false, // Needs turned off for generateSourceMaps
                optimize: "uglify2", // Supports generateSourceMaps
                out: "assets/javascripts/build.js"
            }
        }
    },

如果我将它放在定义调用中的文件顶部,我可以让它在 almond 中正常工作,但是在 AMD 中保持精简不是更可取吗?


根据 Almond 文档,它最适合非动态加载并将所有内容打包到一个文件中。

您应该能够在编译选项中将“findNestedDependency”设置为 true,以确保内联 require 调用作为构建的一部分包含在内。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

内联 require() 在 requirejs 中工作,但不适用于优化的 almond 构建 的相关文章

随机推荐