[工具配置]requirejs 多页面,多入口js文件打包总结
需要明确以下几点:
1.本地前端调试代码肯定是调用原始的路径以及代码,但是线上运行的肯定是通过打包后的另一个路径,这儿就是生成的dist文件夹了。
2.requirejs的引入,线上跟线下的路径怎么控制?我们是这样控制的,代码如下:
<script src="${resource}/js/base/require.js" data-main="${resource}/js/accountMain"></script>
这个${resource}是服务端控制传递到页面中的,在本地调试这个${resource}的值就是/resource/v1/;那么到了线上这个值就是/dist/v1/了。所以这个js线上跟线下的配合就完成了。本地调试调用的是/resource/v1/下面的资源,在线上就是/dist/v1/下的资源,当然这个v1其实是多余的,当时主要是为了做版本发布添加的版本号。
下面我们就一步一步来讲解下如何把resource/v1/js/下的入口文件都打包。
首先看一下我的所有入口文件在哪儿,如图所示:

这些js就是在resource/v1/js/下面。
入口现在有11个js文件,都需要把所引入的模块都打包到各自的入口js中。
第一步,我copy原始资源中的fonts,images,css以及js中base下的js,其中base下的js文件主要是基本的库,包括requirejs库等。复制到dist文件夹下。
复制的作用是,在线上我也需要dist下的fonts,images,css。
copy: {
            /*
          main: {
            expand: true,
            cwd: 'src',
            src: '**',
            dest: 'dist/',
          },
          */
          main:{
              files:[
                {expand: true,cwd: 'resources/v1/css/',src: '**',dest:'dist/v1/css/'},
                {expand: true,cwd: 'resources/v1/fonts/',src: '**',dest:'dist/v1/fonts/'},
                {expand: true,cwd: 'resources/v1/images/',src: '**',dest:'dist/v1/images/'},
                {expand: true,cwd: 'resources/v1/js/base/',src: '**',dest:'dist/v1/js/base/'}
              ]
          }
        }
第二步,通过grunt-contrib-requirejs打包入口文件。配置文件如下:
// r.js 打包准备
var files = grunt.file.expand('resources/v1/js/*.js');
var requirejsOptions = {}; //用来存储 打包配置的对象
//遍历文件
files.forEach(function(file,index,array) {
var name = file.substring(file.lastIndexOf('/') + 1);
var reqname = name.replace(/\.js$/,'');
console.log(name);
var filename = 'requirejs' + index;
requirejsOptions[filename] = {
options: {
baseUrl: "resources/v1/js",
paths:{
"jquery":'base/jquery-1.11.3.min',
'vue':'base/vue.min',
"vuedraggable":'base/vuedraggable',
'bootstrap':'base/bootstrap.min',
"sortablejs":'base/Sortable',
"basicLib":'widgets/basicLib',
'msg':'widgets/msg',
'baseUrl':'widgets/baseUrl',
'common':'widgets/common',
"ajaxfileupload":'widgets/ajaxfileupload',
'document':'widgets/document',
"comp":'widgets/comp',
'header':'module/header',
'accountCenter':'view/accountCenter',
'docking':'view/docking',
'templateUploadCtr':'view/templateUploadCtr'
},
shim:{
'vue':{
exports:'vue'
},
'basicLib':['jquery'],
'bootstrap':['jquery'],
'ajaxfileupload':['jquery'],
'sortablejs':['vue']
},
optimizeAllPluginResources: true,
name: reqname,
out: 'dist/v1/js/' + name
}
};
});
接着初始化配置以及加载注册任务
grunt.initConfig({
    requirejs: requirejsOptions
})
grunt.loadNpmTasks('grunt-contrib-requirejs');
grunt.registerTask('default', ['requirejs']);
由于我的代码中有es6语法,所以合并后把其中的es6语法转化成es5的;再后面在压缩去掉注释什么的。
总的配置代码如下:
    module.exports = function(grunt) {
    // r.js 打包准备
    var files = grunt.file.expand('resources/v1/js/*.js');
    var requirejsOptions = {}; //用来存储 打包配置的对象
    //遍历文件
    files.forEach(function(file,index,array) {
        var name = file.substring(file.lastIndexOf('/') + 1);
        var reqname = name.replace(/\.js$/,'');
        console.log(name);
        var filename = 'requirejs' + index;
        requirejsOptions[filename] = {
            options: {
                baseUrl: "resources/v1/js",
                paths:{
                    "jquery":'base/jquery-1.11.3.min',
                    'vue':'base/vue.min',
                    "vuedraggable":'base/vuedraggable',
                    'bootstrap':'base/bootstrap.min',
                    "sortablejs":'base/Sortable',
                    "basicLib":'widgets/basicLib',
                    'msg':'widgets/msg',
                    'baseUrl':'widgets/baseUrl',
                    'common':'widgets/common',
                    "ajaxfileupload":'widgets/ajaxfileupload',
                    'document':'widgets/document',
                    "comp":'widgets/comp',
                    'header':'module/header',
                    'accountCenter':'view/accountCenter',
                    'docking':'view/docking',
                    'templateUploadCtr':'view/templateUploadCtr'
                },
                shim:{
                    'vue':{
                        exports:'vue'
                   },
                    'basicLib':['jquery'],
                    'bootstrap':['jquery'],
                    'ajaxfileupload':['jquery'],
                    'sortablejs':['vue']
                },
                optimizeAllPluginResources: true,
                name: reqname,
                out: 'dist/v1/js/' + name
            }
        };
    });
    //配置参数
    grunt.initConfig({
        pkg: grunt.file.readJSON('package.json'),
        requirejs:requirejsOptions,
        watch: {
           js: {
            files:['resources/**/*.js'],
            tasks:['default'],
            options: {livereload:false}
          },
          babel:{
              files:'resources/**/*.js',
              tasks:['babel']
          }
        },
        jshint:{
            build:['resources/**/*.js'],
            options:{
                jshintrc:'.jshintrc' //检测JS代码错误
            }
        },
        copy: {
            /*
          main: {
            expand: true,
            cwd: 'src',
            src: '**',
            dest: 'dist/',
          },
          */
          main:{
              files:[
                {expand: true,cwd: 'resources/v1/css/',src: '**',dest:'dist/v1/css/'},
                {expand: true,cwd: 'resources/v1/fonts/',src: '**',dest:'dist/v1/fonts/'},
                {expand: true,cwd: 'resources/v1/images/',src: '**',dest:'dist/v1/images/'},
                {expand: true,cwd: 'resources/v1/js/base/',src: '**',dest:'dist/v1/js/base/'}
              ]
          }
        },
        babel: {
            options: {
                sourceMap: false,
                presets: ['babel-preset-es2015']
            },
            dist: {
                files: [{
                   expand:true,
                   cwd:'dist/v1/js/', //js目录下
                   src:['*.js'], //所有js文件
                   dest:'dist/v1/js/'  //输出到此目录下
                 }]
            }
        },
        uglify: {
            options: {
                mangle: true, //混淆变量名
                comments: 'false' //false(删除全部注释),some(保留@preserve @license @cc_on等注释)
            },
            my_target: {
                 files: [{
                   expand:true,
                   cwd:'dist/v1/js/', //js目录下
                   src:['*.js'], //所有js文件
                   dest:'dist/v1/js/'  //输出到此目录下
                 }]
            }
        }
    });  
      //载入uglify插件,压缩js
      grunt.loadNpmTasks('grunt-contrib-copy');
      grunt.loadNpmTasks('grunt-babel');
      //grunt.loadNpmTasks('grunt-contrib-jshint');
      grunt.loadNpmTasks('grunt-contrib-uglify');
      grunt.loadNpmTasks('grunt-contrib-requirejs');
      grunt.loadNpmTasks('grunt-contrib-watch');
      //注册任务
      grunt.registerTask('default', ['copy','requirejs','babel','uglify']);
      grunt.registerTask('watcher',['watch']);
    }  
参考地址:
使用grunt完成requirejs的合并压缩和js文件的版本控制
requirejs 多页面,多js 打包代码,requirejs多对多打包【收藏】
[工具配置]requirejs 多页面,多入口js文件打包总结的更多相关文章
- [工具配置]使用requirejs模块化开发多页面一个入口js的使用方式
		描述 知道requirejs的都知道,每一个页面需要进行模块化开发都得有一个入口js文件进行模块配置.但是现在就有一个很尴尬的问题,如果页面很多的话,那么这个data-main对应的入口文件就会很多. ... 
- 使用requirejs模块化开发多页面一个入口js的使用方式
		描述 知道requirejs的都知道,每一个页面需要进行模块化开发都得有一个入口js文件进行模块配置.但是现在就有一个很尴尬的问题,如果页面很多的话,那么这个data-main对应的入口文件就会很多. ... 
- requirejs 多页面,多js 打包代码,requirejs多对多打包【收藏】
		这段代码来自 http://stackoverflow.com/questions/20583812/grunt-requirejs-optimizer-for-a-multi-app-project ... 
- requirejs 多页面,多js 打包代码,requirejs多对多打包
		这段代码来自 http://stackoverflow.com/questions/20583812/grunt-requirejs-optimizer-for-a-multi-app-project ... 
- JS跨页面或跨JS文件对变量赋值
		JS跨页面或跨JS文件对变量赋值,这是很小的一个问题. 但问题虽小,却总觉得有点不够自然,不爽. 为什么呢?访问一个页面上的变量不是什么难事,比如用parent.变量名,或者windows名.变量名, ... 
- 使用grunt完成requirejs的合并压缩和js文件的版本控制
		最近有一个项目使用了 requirejs 来解决前端的模块化,但是随着页面和模块的越来越多,我发现我快要hold不住这些可爱的js文件了,具体表现在每个页面都要设置一堆 requirejs 的配置( ... 
- 静态HTML页面不缓存js文件的方法
		今天做项目时候遇到一个问题,由于采用了生成静态的CMS系统,但是页面头部需要显示用户登录的信息,也就是,没有登录时,显示登录框,用户登录后,则显 示登录信息.于是用到了js调用php文件的方法.但是由 ... 
- 过滤器会拦截  前端页面加载 js文件的请求
		学艺不精啊.....之前就总结过博客: JAVA中解决Filter过滤掉css,js,图片文件等问题 结果现在又犯了老错误~ 情况如下: index.jsp 页面的验证码输入栏绑定了异步验证(jQur ... 
- vue页面引入外部js文件遇到的问题
		问题一:vue文件中引入外部js文件的方法 //在vue文件中 <script> import * as funApi from '../../../publicJavaScript/pu ... 
随机推荐
- es5
			var arr1=["上海","北京","广州"]; var arr2=[12,22, 33,58,32,45,92]; // 数组.方法( ... 
- 【app】Hybrid?Native?不知道你就out了!
			Hybrid?是个啥? 相信大家在平常生活中也会经常见到这个词,比如现在比较火的hybrid汽车(混合动力汽车) 那如果是针对于App而言呢? 那就要从App的分类说起了 目前主流应用程序大体分为三类 ... 
- vue属性监听
			1.watch:用来监听每一个属性的变化 2.watch这个对象里面都是函数,函数的名称是data中的属性名称,watch中的函数不需要调用 3.当属性发生改变那么就会触发watch函数,每个函数都会 ... 
- Excel 逻辑函数if使用方法
			Excel 逻辑函数if使用方法 
- Jenkins系列之七——前端app自动打包
			了两周终于搞掂了,期间各种搜教程.各种懵逼,各种坑对小白来还是很难的额.废话不多说直接开撸~~~ 一.介绍下什么是Gradle Gradle是一个基于JVM的构建工具,是一款通用灵活的构建工具,支持m ... 
- C# Windows异步I/O操作
			1.简介 关于Windows的异步I/O操作,只要解决的是同步I/O操作的线程利用率问题,通过异步I/O Api来提升线程的利用率,提升系统的吞吐能力,将各种I/O操作交给线程池然后交由硬件设备执行, ... 
- json_decode与json_encode容易被忽视的点
			一.json_decode的使用,json_decode共有4个参数 json_decode ( string $json [, bool $assoc=FALSE [, int $depth= 51 ... 
- NLog 自定义Target
			http://nlog-project.org/2015/06/30/extending-nlog-is-easy.html 新建一个类库,命名规则为NLog.*.dll 定义一个类输出日志到Rabb ... 
- CDlinux系统破解无线wifi
			CDlinux是破解无线wifi信号的很好用的系统.它就像一个PE,不过它是基于Linux内核的微型系统.里面的破解工具很齐全,既有传统的抓包工具,也有最新的PIN码破解软件,而且针对windows用 ... 
- Docker容器中开始.Net Core之路
			开始写这篇博客前,已经尝试练习过好多次Docker环境安装,.Net Core环境安装了,在这里替腾讯云做一个推广,假如我们想学习.练手.net core 或是Docker却苦于没有开发环境,服务器也 ... 
