[工具配置]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 ...
随机推荐
- 从字节码看java中 this 的隐式传参
从字节码看java中 this 隐式传参具体体现(和python中的self如出一辙,但是比python中藏得更深),也发现了 static 与 非 static 方法的区别所在! static与非s ...
- MyBatis 一级缓存和二级缓存及ehcache整合
一级缓存 什么是缓存?? 缓存是存储在内存(cache)中的数据,一般情况都存在内存,在内存数据存储满了,会存储到硬盘上(disk),或是在我们进行一些操作和配置也可以把缓存存储到磁盘中. 缓存的作用 ...
- python --商品评价---- 数据表结构以及理解
商品评论(评价)功能 1.概述 评论功能已经成为APP和网站开发中的必备功能.本文主要介绍评论功能的数据库设计. 评论功能最主要的是发表评论和回复评论(删除功能在后台).评论功能的拓展功能体现有以下几 ...
- 【sping揭秘】25、Spring远程方案
分化:RMI,EJB,Hessian Spring有 Rmi,http,hessian,burlap 基于rmi的remoting方案 RMI要求远程类对象包路径和本地一致 基于HTTP的轻量级rem ...
- Android数据保存之文件保存
前言: 上一篇文章写了在Android中利用SharedPreferences保存数据,SharedPreferences在保存数据的时候主要是保存一些应用程序的设置信息或者少量的用户信息,并且是以k ...
- Spring 事务传播实践分析
事务管理是应用系统开发中必不可少的一部分.事物将若干的数据库操作作为一个整体控制,一起成功或一起失败.事物有以下特性 原子性:指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生. ...
- 配置babel
配置babel ECMAScript的版本,每年都会定期举行会议,发布各种标准,当前版本到了2019,但大部分人使用的浏览器,都可以支持es2015,也就是es6,要等到大部分浏览器都支持到最新版本, ...
- 一个注意事项:内部类引用的外部变量必须是final的
之前写过一个项目,好久没更新了,最近翻起以前的代码,发现在这里报了一个错.(现在转到Intellij了,从前在Eclipse luna中是可以编译通过的,Eclipse mars也会报错,JDK版本都 ...
- javase基础回顾(三) 动态代理
动态代理是大型框架中经常用到的经典的技术之一,博主在理解spring的控制反转(依赖注入)的思想时回头着重复习了一下java的动态代理. 在说动态代理之前我们先简单说一说代理是用来干什么的,用于什么样 ...
- ASP.NET WEB API简介
ASP.NET WEB API是基于.NET Framework用来构建Restful软件架构的框架,它是基于HTTP协议.Http不只是能够生成我们常见的web页面,它更是能够建立服务和面向资源 ...