我有以下目录结构(仅相关位):
app
- build
- script.js
- js
- lib
- require.js
- jquery-1.10.2.js
- app.js
- index.html
Gruntfile.jsGruntfile.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中即可。
发布于 2014-01-03 08:26:49
您可以定义一个mainConfigFile,并且内部配置文件有到库代码的路径,如下所示
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将将所有路径文件的内容添加到优化的代码中。
发布于 2015-04-06 19:37:51
尝试将其添加到options对象中:
findNestedDependencies: true通过这种方式,grunt-contrib(实际上仅仅是requirejs)将发现配置文件中列出的所有依赖项。
希望它对你有用。
https://stackoverflow.com/questions/20617504
复制相似问题