使用gulp进行css、js压缩
var gulp = require('gulp');
var cleanCSS = require('gulp-clean-css');
var concatCss = require('gulp-concat-css');
var uglify = require('gulp-uglify');
var concat = require('gulp-concat');
var del = require('del');
var gutil = require('gulp-util');
//压缩的临时文件保存到storage, gitignore这些文件
var clean_css_path = 'storage/gulp/clean_css'; //压缩css文件保存路径
var target_css_path = 'public/gulp/css'; //最终生成的最小化css文件保存路径
var clean_js_path = 'storage/gulp/clean_js'; //压缩js文件保存路径
var target_js_path = 'public/gulp/js'; //最终生成的最小化js文件保存路径
//为数组每一个元素加上前缀并返回修改后的数组
//这个前缀是相对于项目根目录的目录前缀
Array.prototype.add_prefix = function (prefix) {
return this.map(function (path) {
return prefix + path;
});
};
//需要合并压缩的css
var css_to_clean = [
'js/jquery-ui/css/no-theme/jquery-ui-1.10.3.custom.min.css',
'css/font-icons/entypo/css/entypo.css',
'css/bootstrap.css',
'css/neon-core.css',
'css/neon-theme.css',
'css/neon-forms.css',
'css/custom.css',
'js/datatables/datatables.min.css',
'js/dropzone/dropzone.css'
].add_prefix('public/static/neon-res/')
.concat([
'fancybox/jquery.fancybox.css',
'fancybox/helpers/jquery.fancybox-buttons.css',
'fancybox/helpers/jquery.fancybox-thumbs.css'
].add_prefix('public/static/'))
.concat('public/admin/css/neon_common.css');//自定义的css
//需要合并压缩的js
var js_to_clean = [
//登录界面才有的js
//下面合并js使用slice(2)去掉
'jquery.validate.min.js',
'neon-login.js',
'jquery-1.11.3.min.js',
'gsap/TweenMax.min.js',
'jquery-ui/js/jquery-ui-1.10.3.minimal.min.js',
'bootstrap.js',
'joinable.js',
'resizeable.js',
'neon-api.js',
'fileinput.js',
'dropzone.js',
'neon-chat.js',
'neon-custom.js',
'neon-demo.js'
].add_prefix('public/static/neon-res/js/')
.concat([
//自定义的js
'public/admin/js/common.js',
'public/admin/js/kollway_ot.js'
])
.concat([
'public/static/uploadify/jquery.uploadify.min.js',
'public/static/H5FileUploader.js'
])
.concat([
'jquery.fancybox.pack.js',
'helpers/jquery.fancybox-buttons.js',
'helpers/jquery.fancybox-thumbs.js'
].add_prefix('public/static/fancybox/'));
//压缩全部css, 直接全部合并之后好像漏掉一些css, 先压缩再合并
gulp.task('clean-css', function () {
return gulp.src(css_to_clean)
.pipe(cleanCSS())
.pipe(gulp.dest(clean_css_path));
});
var clean_css_callback = function () {
var temp_array = css_to_clean.map(function (path) {
//只获取文件名
return clean_css_path + '/' + path.split('/').pop();
});
return gulp.src(temp_array)
.pipe(concatCss('all.min.css', {basedir: target_css_path}))
.pipe(cleanCSS())
.pipe(gulp.dest(target_css_path));
};
gulp.task('css', ['clean-css'], clean_css_callback);
//js
//压缩所有js
gulp.task('clean-js', function () {
return gulp.src(js_to_clean)
.pipe(uglify())
.pipe(gulp.dest(clean_js_path));
});
var clean_js_callback = function () {
//slice(2), 去掉登录界面的两个
var temp_array = js_to_clean.slice(2).map(function (path) {
return clean_js_path + '/' + path.split('/').pop();
});
return gulp.src(temp_array)
.pipe(concat('all.min.js', {basedir: target_js_path}))
.pipe(gulp.dest(target_js_path));
};
gulp.task('js', ['clean-js'], clean_js_callback);
//清理临时文件, 需要的话清除, 使用gulp clean命令
gulp.task('clean', function () {
del([
clean_css_path + '/' + '*.css',
clean_js_path + '/' + '*.js'
]);
});
//合并登陆页所需css
gulp.task('merge-login-css', ['clean-css'], function () {
return gulp.src([
'jquery-ui-1.10.3.custom.min.css',
'entypo.css',
'bootstrap.css',
'neon-core.css',
'neon-theme.css',
'neon-forms.css',
'custom.css'
].map(function (path) {
return clean_css_path + '/' + path;
})).pipe(concatCss('login.min.css'), {basedir: target_css_path})
.pipe(cleanCSS())
.pipe(gulp.dest(target_css_path))
});
//合并登陆页所需js
gulp.task('merge-login-js', ['clean-js'], function () {
return gulp.src([
'jquery-1.11.3.min.js',
'TweenMax.min.js',
'jquery-ui-1.10.3.minimal.min.js',
'bootstrap.js',
'joinable.js',
'resizeable.js',
'neon-api.js',
'jquery.validate.min.js',
'neon-login.js',
'neon-custom.js',
'neon-demo.js'
].map(function (path) {
return clean_js_path + '/' + path
}))
.pipe(concat('login.min.js', {basedir: target_js_path}))
.pipe(gulp.dest(target_js_path));
});
//登录页面的css、js和base的不一样, 独立生成, 先清除缓存文件
//一般不需要更改
gulp.task('login', ['merge-login-css', 'merge-login-js']);
//如果只是改变自定义的css、js, 只压缩自定义的css、js
//前提是之前已经压缩过其他文件, 并且没有删除
//压缩自定义css
gulp.task('clean-custom-css', function () {
return gulp.src('public/admin/css/neon_common.css')
.pipe(cleanCSS())
.pipe(gulp.dest(clean_css_path));
});
//压缩自定义js
gulp.task('clean-custom-js', function () {
return gulp.src([
'public/admin/js/common.js',
'public/admin/js/kollway_ot.js'
]).pipe(uglify()).pipe(gulp.dest(clean_js_path));
});
//如果之前已经用过gulp生成所有中间压缩文件
//修改了自定义的几个文件之后可以直接使用gulp custom利用缓存文件生成新的压缩文件
gulp.task('cache-clean-css', ['clean-custom-css'], clean_css_callback);
gulp.task('cache-clean-js', ['clean-custom-js'], clean_js_callback);
gulp.task('custom', ['cache-clean-css', 'cache-clean-js']);
gulp.task('default', ['css', 'js']);
使用gulp进行css、js压缩的更多相关文章
- gulp之css,js压缩合并加密替换
为了防止客户端的静态资源缓存,我们需要每次更新css或js的时候,通过md5或时间戳等方式重新命名静态资源.让客户端可以重新请求资源,而不是从缓存里取.然后html模板里的src也要做相应的修改.当然 ...
- gulp为css,js添加版本号
由于cdn缓存,更改样式后会有一段时间不生效,解决方法就是给css,js加上版本号效果如下: 1.安装gulp插件 npm install --save-dev gulp-rev (version:9 ...
- ASP.NET MVC 中CSS JS压缩合并 功能的使用方法
通过压缩合并js文件和css文件,可以减少 服务器的响应 次数和 流量,可以大大减小服务器的压力,对网站优化有比较明显的帮助!压缩合并 css 文件和js文件是网站优化的一个 比较常用的方法. ASP ...
- 【转】asp.net mvc css/js压缩合并 --- combres
转自:http://www.cnblogs.com/zxktxj/archive/2012/05/30/2526246.html NuGet 网站:http://nuget.codeplex.co ...
- maven css/js 压缩配置
<plugin> <groupId>net.alchim31.maven</groupId> <art ...
- gulp做简单的js压缩
安装工具 全局安装npm install --global gulp 项目的依赖安装npm install --save-dev gulp npm install --save-dev gulp-re ...
- gulp自动刷新和css、js压缩
之前搭建过Grunt,但是用起来有点繁琐,后来有人跟我说gulp更多简单.所以今天又搭建一个gulp.在使用gulp前应该有nodeJs环境,安装完nodejs后,就可以开始gulp的搭建了. 先新建 ...
- 运用Gulp压缩文件编译文件。包括css js html image
安装node.js npm 以及安装gulp等方法我就不在这里赘述了. 接下里我主要介绍的是Gulpfile文件里面的配置该如何书写. var gulp = require('gulp');//引 ...
- Gulp实现css、js、图片的压缩以及css、js文件的MD5命名
目前做代码压缩合并的工具有很多,诸如gulp,webpack,grunt等等,可以说这些项目构建工具的功能非常之强大:图片压缩.图片转base64.css和js的压缩以及合并,文件的md5重命名 -- ...
- gulp插件构建项目 压缩js、css、image、zip、web服务、跨域等插件
推荐一个很好文: https://github.com/lin-xin/blog/issues/2 匹配符 *.**.!.{} gulp.src('./js/*.js') // * 匹配js文件夹下所 ...
随机推荐
- 【坚持】Selenium+Python学习之从读懂代码开始 DAY3
2018/05/15 [来源:菜鸟教程](http://www.runoob.com/python3/python3-examples.html) #No.1 list = [1, 2, 3, 4] ...
- Valgrind 简单用法
有时需要给自己写的小程序做个简单的 benchmark,查看内存使用情况和运行时间.这时可以试试 valgrind. Ubuntu 下安装很简单: sudo apt-get update sudo a ...
- Dubbo背景和简介
转载出处 Dubbo开始于电商系统,因此在这里先从电商系统的演变讲起. 单一应用框架(ORM) 当网站流量很小时,只需一个应用,将所有功能如下单支付等都部署在一起,以减少部署节点和成本. 缺点:单一的 ...
- 武汉天喻信息 移动安全领域 SE(Secure Element)
产品简介: SE(Secure Element)为安全模块,是一台微型计算机,通过安全芯片和芯片操作系统(COS)实现数据安全存储.加解密运算等功能.SE可封装成各种形式,常见的有智能卡和嵌入式安全模 ...
- OOP 2.2 构造函数
1.概念 成员函数的一种 名字与类名相同,可以有参数,没有返回值(void也不行) 作用:对对象进行初始化,如给成员函数赋初始值 如果定义时没有构造函数,则编译器生成一个默认无参数的构造函数 默认构造 ...
- 引用百度bcebos jar 503问题
最近使用jeecms管理公司各个站点,关于附件部分采用bos进行上传处理. 在引用bosjar的时候,出现503问题,打断点打印异常堆栈信息,也获取不到.后来使用watch,发现BosClientCo ...
- 在selenium测试中使用XPATH功能函数starts-with、contains、descendant、ancestor、text()定位网页元素
项目中一些使用xpath函数的复杂例子,记录于此 1. 使用starts-with //div[starts-with(@id,'res')]//table//tr//td[2]//table//tr ...
- 【Linux】- 简明Vim练习攻略
vim的学习曲线相当的大(参看各种文本编辑器的学习曲线),所以,如果你一开始看到的是一大堆VIM的命令分类,你一定会对这个编辑器失去兴趣的.下面的文章翻译自<Learn Vim Progress ...
- Win2019 + Oracle18c SQLPLUS 命令行出现乱码的解决
1. Win2019 中文版 安装了 Oracle数据库, dbca 建库时选择的 的字符集是 ZHS16GBK 然后发现使用sqlplus 时有乱码的现象如图示: 2. csdn 上面有一个博客有解 ...
- MySQL---索引算法B+/B-树原理(一)
B-树 1 .B-树定义 B-树是一种平衡的多路查找树,它在文件系统中很有用. 定义:一棵m 阶的B-树,或者为空树,或为满足下列特性的m 叉树: ⑴树中每个结点至多有m 棵子树: ⑵若根结点不是叶子 ...