首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >grunt requirejs‘未定义’

grunt requirejs‘未定义’
EN

Stack Overflow用户
提问于 2013-03-06 20:11:21
回答 4查看 16.7K关注 0票数 14

我正在尝试使用GruntJS优化RequireJS,使用grunt-contrib-requirejs插件。

问题是我的代码在优化之前运行得很好,然后在优化之后,在控制台上显示为Uncaught ReferenceError: define is not defined

这是Gruntfile.js

代码语言:javascript
复制
module.exports = function (grunt) {
  grunt.loadNpmTasks('grunt-contrib-requirejs');

  grunt.initConfig({
    requirejs: {
        compile : {
            options : {
              name  : 'main',
              baseUrl : ".",
              mainConfigFile : "./main.js",
              out : "./optimized.js",
              preserveLicenseComments: false
           }
        }
}
  })

  grunt.registerTask('default', 'requirejs');

}
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2013-03-09 17:13:35

由于define是一个requireJs函数,因此您似乎错过了加载requireJs或任何其他AMD加载器的过程。如果你不需要加载任何其他AMD模块,那么你只需编译一次,你可以使用像almond这样的轻量级加载程序垫片。

票数 8
EN

Stack Overflow用户

发布于 2013-12-14 11:24:18

将require.js文件添加为"include“选项应该可以。

代码语言:javascript
复制
requirejs: {
    compile : {
        options : {
            name  : 'main',
            baseUrl : ".",
            mainConfigFile : "./main.js",
            out : "./optimized.js",
            preserveLicenseComments: false,
            include: ['path/to/require.js']
        }
    }
}
票数 12
EN

Stack Overflow用户

发布于 2016-09-30 21:55:47

正如前面所指出的,需要的脚本是缺失的。

这是官方要求的页面建议你这样做的方式(摘自我的gruntfile文件):

代码语言:javascript
复制
requirejs: {
  compile: {
    options: {
      baseUrl: "src/js",
      mainConfigFile: 'src/js/require.config.js', 
      paths: {
        requireLib: "vendor/require/require"
      },
      include: "requireLib",
      name: "require.config",
      out: "dist/js/bundle.js"
    }
  }
},

注意到选项包括路径和,这两个选项对于定义require至关重要。你只需要在你需要的.js-文件中添加一个需要的file选项。

官方答案请看这里:http://requirejs.org/docs/optimization.html#onejs

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/15247048

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档