gulp实时编译less,压缩合并requirejs模块文件
gulp的使用命令简单,就几个,gulp的简单使用教材可以参考一点的gulp使用教材(http://www.ydcss.com/archives/18)。
下面就简单的介绍这些命令如何互相配合的完成前端的构建工作。
项目结构:

首先全局安装gulp,使用命令:npm install -g gulp
一:gulp实时编译less
var gulp = require('gulp');
var gulpLess = require('gulp-less');
var gulpMinifyCss = require('gulp-minify-css');
var gulpSourcemaps = require('gulp-sourcemaps');
这4个插件就是目前用到的,需要其他功能可以自己添加。gulp-less是编译less用的插件,gulp-minify-css是压缩css的插件,gulp-sourcemaps是便于压缩后代码调试的。
gulp.task('allLess', function(){
gulp.src('src/less/**/*.less')
.pipe(gulpSourcemaps.init())//sourcemaps
.pipe(gulpLess())//编译less
.pipe(gulpSourcemaps.write())
.pipe(gulp.dest('src/css/'))
.pipe(gulpMinifyCss())//压缩css
.pipe(gulpSourcemaps.write())
.pipe(gulp.dest('dist/css/'));
});
gulp.watch('src/less/**/*.less', ['allLess']);
gulp.task('default', ['allJs', 'allLess']);
gulp.src('src/less/**/*.less'):src/less/下任意目录下的less文件,**代表任意单个或多个目录,*.less表示已less后缀结尾的文件。
gulp.watch('src/less/**/*.less', ['allLess']);这条是监听src/less目录下的任意less文件的变化,有变化就会调用allLess任务编译变化的less文件。
gulp实时编译less就是这么简单了。还可以加入对图片的压缩控制。
二:gulp压缩合并requirejs加载的js模块文件
在前端代码量越来越多的情景下,js模块化编程孕育而生,AMD模式的模块采用requirejs来加载模块。模块化编程让前端js代码规范整洁之外,也导致了浏览器对
js请求数量增多,这个时候,就需要对相应的模块进行合并,并且压缩代码,减少请求,缩短页面响应时间。
一些需要的模块:
var fs = require('fs');
var paths = require('path');
var rjs = require('requirejs');
合并压缩用的是requirejs的optimize方法,
先定义一些变量:
// 配置目录
var jsDir = 'src/js'; // 所有要编译的js模块
var jsModules = [], ctrlModules = [],
commModules = [
{
name: "lib/common",
exclude: []
}
];
合并压缩代码的思路就是要告诉requirejs哪些模块需要合并到文件中,哪些模块要单独打包,不用合并到文件中,并且单独请求。也就是要先遍历你的逻辑js文件,
把名称和需要过滤的模块名称存到变量中,然后传递给requirejs的optimize方法。下面是变量controller下的js文件。
// 初始化controller下所有要编译的js模块
function initJsPath(path){
path = path || jsDir + '/controller';
var files = fs.readdirSync(path);/*读取目录下的所有文件名称,返回名称数组,如果文件名是目录,该目录下面的文件不会读取*/
console.log(files);
files.forEach(function(item) {
var tmpPath = path + '/' + item,
stats = fs.statSync(tmpPath);
if (stats.isDirectory()) {//目录
initJsPath(tmpPath);
} else {//文件
if (tmpPath.slice(-3)=='.js') {
ctrlModules.push({
name: tmpPath.slice(jsDir.length + 1, -3),
exclude: ['lib/common']
});
}
}
});
console.log(ctrlModules);
}
gulp中定义的任务是:
gulp.task('allJs', function(cb){
console.log('======================================= start optimize js ==========================================');
//收集js文件名称
initJsPath();
jsModules = commModules.concat(ctrlModules);
rjs.optimize({
baseUrl: 'src/js',
dir: 'dist/js',
findNestedDependencies : false, //代码内部写的require也计算在打包内
preserveLicenseComments : false, //去掉头部版权声明
removeCombined: false, //自动删除被合并过的文件
modules: jsModules
}, function(){
cb();
}, cb);
});
baseUrl目录下的文件都会被压缩,modules中的模块会被合并并且压缩,合并压缩后存储到dist/js目录下面。commModules中存储的是我们项目的公共模块文件,
需要单独合并压缩抽离出来,这个文件不会被合并到其他模块文件中,而且会被单独请求。相关参数的配置信息大家可以看官网。
下面看看实验:
index.html:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<script>
window.ENV = 1;
</script>
<body>
<p class="msg">hello rjs</p>
</body>
<script src="src/js/require.js"></script>
<script>
require(['src/js/config.js'], function(){
require(['controller/order/orderDetail']);
});
</script>
</html>
requirejs 的config配置文件:
/**
* Created by jiaan.zhou on 2017/2/3.
*/ var BASEURL = ((window.ENV == 1) || (window.ENV == 2 && location.hash === '#debugon')) ? 'src/js': 'dist/js'; require.config({
waitSeconds: 2000,
baseUrl : BASEURL,
paths : {},
urlArgs : 'v=' + new Date().getTime()
});
没有合并的orderDetai.js文件:
/**
* Created by jiaan.zhou on 2017/2/3.
*/
define('controller/order/orderDetail', ['widget/swipe'], function(widgetSwipe){
console.log('controller/order/orderDetail');
$('.msg').html('success');
});
合并后的orderDetai.js文件:
define("widget/swipe",["lib/common"],function(e){function o(){this.name="swipe",console.log("hello swipe")}return new o}),define("controller/order/orderDetail",["widget/swipe"],function(e){console.log("controller/order/orderDetail"),$(".msg").html("success")});
没有合并模块之前的请求:

从图中我们可以看到所有的模块按照加载顺序进行请求,每个模块对应一个请求。
合并模块后的请求:

合并后,swipe模块已经合并到orderDetai文件中,zepto和fastclick模块合并到commonjs文件中,这样就减少的请求,而且代码也得到压缩。
写的不好,还请大家多多指正,任何问题请联系:QQ 272318930
gulp实时编译less,压缩合并requirejs模块文件的更多相关文章
- gulp之css,js压缩合并加密替换
为了防止客户端的静态资源缓存,我们需要每次更新css或js的时候,通过md5或时间戳等方式重新命名静态资源.让客户端可以重新请求资源,而不是从缓存里取.然后html模板里的src也要做相应的修改.当然 ...
- gulp打包js/css时合并成一个文件时的顺序解决
1.可以使用插进gulp-order. 2.可以这样的写法: return gulp.src(['js/common.js','js/**/*.js']) .pipe(concat('build.js ...
- gulp构建前端,压缩css,js文件,实现浏览器自动刷新
一.安装node nodejs下载地址:https://nodejs.org/ nodejs自带npm模块管理器,安装完成之后打开dos命令窗口输入 node -v就能查看nodejs是否安装成成功 ...
- gulp完成javascript压缩合并,css压缩
最近需要对项目进行优化,主要是对js的压缩合并和css文件的压缩,查找相关资料之后发现gulp可以实现相关的功能,特此分享一下使用心得. 1.安装gulp gulp是基于Node.js的前端构建工具. ...
- 编写gulpfile.js文件:压缩合并css、js
使用gulp一共有四个步骤: 1. 全局安装 gulp: $ npm install --global gulp 2. 作为项目的开发依赖(devDependencies)安装: $ npm inst ...
- ASP.NET MVC 中CSS JS压缩合并 功能的使用方法
通过压缩合并js文件和css文件,可以减少 服务器的响应 次数和 流量,可以大大减小服务器的压力,对网站优化有比较明显的帮助!压缩合并 css 文件和js文件是网站优化的一个 比较常用的方法. ASP ...
- 第十一节:Bundles压缩合并js和css及原理分析
一. 简介 1.背景:浏览器默认一次性请求的网络数是有上限的,如果你得js和css文件太多,就会导致浏览器需要多次加载,影响页面的加载速度, MVC中提供Bundles的方式压缩合并js和css,是M ...
- gulp之压缩合并MD5清空替换加前缀以及自动编译自动刷新浏览器大全
gulp是基于流的前端构件化工具.目前比较火的前端构建化工具还是挺多的,grunt gulp fis3等等. 这个鬼东西有什么用?请参考https://www.zhihu.com/question/3 ...
- gulp css 压缩 合并
//导入工具包 require('node_modules里对应模块') var gulp = require('gulp'), //本地安装gulp所用到的地方 concat = require(' ...
随机推荐
- 转 [ javascript面向对象技术
以下文章来自iteye,作者是 sdcyst ,个人主页 http://www.iteye.com/topic/288813 类变量/类方法/实例变量/实例方法先补充一下以前写过的方法:在javasc ...
- CDOJ 1273 God Qing's circuital law
暴力枚举+idea.做的时候mod写错了,写成了1000000009,找了两个多小时才发现...... a[1],a[2],a[3]....a[N] b[1],b[2],b[3]....b[N] 首先 ...
- (中等) HDU 5293 Tree chain problem,树链剖分+树形DP。
Problem Description Coco has a tree, whose vertices are conveniently labeled by 1,2,…,n.There are ...
- [Unity c#]c#中的反射
什么是反射 在.NET中的反射也可以实现从对象的外部来了解对象(或程序集)内部结构的功能,哪怕你不知道这个对象(或程序集)是个什么东西,另外.NET中的反射还可以运态创建出对象并执行它其中的方法. 反 ...
- CSS重设(reset)
在当今网页设计/开发实践中,使用CSS来为语义化的(X)HTML标记添加样式风格是重要的关键.在设计师们的梦想中都存在着这样的一个完美世界:所有的浏览器都能够理解和适用多有CSS规则,并且呈现相同的视 ...
- java实现——006重建二叉树
public class T006 { public static void main(String[] args){ int pre[] = {1,2,4,7,3,5,6,8}; int in[] ...
- 集群下Cookie共享,必须要设置machineKey
这个节允许你设置用于加密数据和创建数字签名的服务器特定的密钥.ASP.NET自动使用它来保护表单验证Cookie,你也可以将它用于受保护的视图状态数据.同时,这个密钥还用于验证进程外的会话状态提供程序 ...
- osgEarth编译(转载)
osgEarth编译 osgEarth的编译需要osg和一些第三方插件库,我主要参考了cnblogs上的一篇博文,但是也不够详细,并且我是在已经编译好osg的情况下去编译osgEarth,所以期间也遇 ...
- iOS 之 UIStackView
UIStackView是iOS9新推出的布局控件,它的出现,可以说颠覆了以往的布局方式. 问题时,如果我使用UIStackView,它能用在iOS7.8系统中吗? 我要测试一下.测试程序我放到gith ...
- easyui datagrid行中点击a标签链接,行被选中,但是获取不到对应的参数
easyui中使用比较多的就是datagrid了,表格中添加连接,点击跳转,为比较常用的方式;往往在点及标签后调用getSeleted方法会失效; 一.初始代码: {field: 'id',title ...