2 回答
TA贡献1798条经验 获得超3个赞
1 所js文件打包1文件
2 1基础给js按照模块组支持模块1js文件
BUT 都终归结1js文件
我想要我想要页面相关js打包js文件包每页面都自js文件包
简单 基于grunt+grunt-contrib-requirejs
代码 复制代码
// r.js 打包 准备
var files = grunt.file.expand('js/app/*/main.js'); //读取要打包js入口 般都 mainjs
var requirejsOptions = {}; //用存储 打包配置象
//遍历文件
files.forEach(function(file) {
var filenamelist = file.split('/');
var num = filenamelist.length;
var filename = filenamelist[num - 2]; //获取目录名称文件名都mainjs
requirejsOptions[filename] = {
options: {
baseUrl: "js/",
paths: {
"text": 'lib/text',
"jquery": 'lib/jquery',
"backbone": 'lib/backbone',
"underscore": 'lib/underscore',
"Highcharts": 'lib/highcharts/highcharts',
"select2": 'lib/select2/select2',
"moment": 'lib/moment',
"jquery-ui": 'lib/jquery-ui/jquery-ui',
"jq()uery.cookie": 'lib/jquery.cookie',
"validate": 'lib/jquery.validate',
"metadata": 'lib/jquery.metadata',
"jsplumb": "lib/jquery.jsPlumb",
"qtip": 'lib/qtip/jquery.qtip',
"nicescroll": "lib/jquery.nicescroll",
"Htheme": 'lib/highcharts/theme',
'jquery.mousewheel': 'lib/jquery.mousewheel'
},
optimizeAllPluginResources: true,
name: 'app/' + filename + '/main',
out: 'js/appbuild/' + filename + '/main.js'
}
};
});
//
通观察我发现配置r.js build.js 致按照文件名存贮象
与grunt配置则简单
代码 复制代码
//*****省略其代码
requirejs: requirejsOptions
});
// Default task(s).
grunt.registerTask('dev', [
'compass:force',
'connect:server',
'watch'
]);
grunt.registerTask('dist', [
'compass:force'
]);
grunt.registerTask('js', ['requirejs']);
- 2 回答
- 0 关注
- 1721 浏览
添加回答
举报