我有以下目录结构(仅限相关位): app - build - script.js - js - lib - require.js - jquery-1.10.2.js - app.js - index.htmlGruntfile.js Gruntfile.js包含以下内容: module.exports = function (grunt) { var gruntConfig = { pkg:
          app
 - build
   - script.js
 - js
   - lib
     - require.js
     - jquery-1.10.2.js
   - app.js
 - index.html
Gruntfile.js 
 Gruntfile.js包含以下内容:
module.exports = function (grunt) {
    var gruntConfig = {
        pkg: grunt.file.readJSON('package.json'),
        requirejs: {
            compile: {
                options: {
                    name: 'app',
                    baseUrl: 'app/assets/js',
                    out: 'app/assets/build/script.js',
                    include:  ['lib/require'],
                    uglify: {
                        // beautify: true,
                        defines: {
                            DEBUG: ['name', 'false']
                        }
                    },
                    paths: {
                        jquery: "lib/jquery-1.10.2"
                    }
                }
            }
        },
    };
    grunt.initConfig(gruntConfig);
    grunt.loadNpmTasks('grunt-contrib-requirejs');
}; 
 app.js包含以下内容:
require(['jquery'], function ($) {
    // Do stuff
}); 
 我如何设置它以便将所有需要的JavaScript复制到build / script.js中,而不仅仅是app.js和require.js,当我告诉它时(我尝试使用jQuery时出错)?我还希望能够添加模块而不将它们添加到我的Gruntfile中,只需将它们添加到script.js即可.
您可以定义一个mainConfigFile,并且内部配置文件中包含这样的lib代码路径gruntfile的内容:
requirejs: {
  compile: {
    options: {
      baseUrl: "app/js/",
      mainConfigFile: app/config.js",
      out: "build/script.js",
      name: "config"
    }
  }
} 
 配置文件的内容:
require.config({
  paths: {
    lib: "<path to>/js/lib",
    jquery: "<path to>/js/lib/jquery-1.10.2.min",
    .
    and particular file required
    .
  } 
 Requirejs会将所有路径文件的内容添加到优化代码中.
