首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >尝试使用grunt-cont排骨要求将所有JS缩小到一个文件。

尝试使用grunt-cont排骨要求将所有JS缩小到一个文件。
EN

Stack Overflow用户
提问于 2013-12-16 17:55:06
回答 2查看 8.7K关注 0票数 4

我有以下目录结构(仅相关位):

代码语言:javascript
复制
app
 - build
   - script.js
 - js
   - lib
     - require.js
     - jquery-1.10.2.js
   - app.js
 - index.html
Gruntfile.js

Gruntfile.js包含以下内容:

代码语言:javascript
复制
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包含以下内容:

代码语言:javascript
复制
require(['jquery'], function ($) {
    // Do stuff
});

如何设置它,以便它将所需的所有JavaScript复制到build/script.js中,而不仅仅是app.js和require.js (当我尝试使用jQuery时出错)?我还希望能够添加模块,而无需将它们添加到Gruntfile中,只需将它们添加到script.js中即可。

EN

回答 2

Stack Overflow用户

发布于 2014-01-03 08:26:49

您可以定义一个mainConfigFile,并且内部配置文件有到库代码的路径,如下所示

gruntfile的内容:

代码语言:javascript
复制
requirejs: {
  compile: {
    options: {
      baseUrl: "app/js/",
      mainConfigFile: app/config.js",
      out: "build/script.js",
      name: "config"
    }
  }
}

配置文件的内容:

代码语言:javascript
复制
require.config({
  paths: {
    lib: "<path to>/js/lib",
    jquery: "<path to>/js/lib/jquery-1.10.2.min",
    .
    and particular file required
    .
  }

Requirejs将将所有路径文件的内容添加到优化的代码中。

票数 1
EN

Stack Overflow用户

发布于 2015-04-06 19:37:51

尝试将其添加到options对象中:

代码语言:javascript
复制
findNestedDependencies: true

通过这种方式,grunt-contrib(实际上仅仅是requirejs)将发现配置文件中列出的所有依赖项。

希望它对你有用。

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

https://stackoverflow.com/questions/20617504

复制
相关文章

相似问题

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