Gulp实现css、js、图片的压缩以及css、js文件的MD5命名

目前做代码压缩合并的工具有很多,诸如gulp,webpack,grunt等等,可以说这些项目构建工具的功能非常之强大:图片压缩、图片转base64、css和js的压缩以及合并,文件的md5重命名 ……。本人之前也是在项目中没具体使用过,闲来无事,查查资料,自己写了一个用gulp工具的小demo,有很多不足之处,欢迎指点。

第一步:安装node和npm

不用说,要用gulp,得先安装node和npm(安装完node后,自带有npm)

Node官网下载地址:https://nodejs.org/en/download/(具体怎么安装请自行查资料)

第二步:安装需要的插件

使用npm安装需要的插件(命令后面加 -g 表示全局安装,加 --save-dev 只安装到当前项目)

由于当前项目要使用,所以这些插件必须得安装到本项目中

安装命令如下:

npm init     //- 会生成一个package.json文件
npm install gulp --save-dev     //- gulp插件的核心
npm install gulp-minify-css --save-dev     //- 压缩CSS文件
npm install gulp-rev --save-dev         //- 对css、js文件名加MD5后缀
npm install gulp-rev-collector --save-dev   //- 路径替换
npm install gulp-clean --save-dev            //- 用于删除文件
npm install gulp-uglify --save-dev            //- 压缩js代码
npm install gulp-imagemin --save-dev      //- 压缩图片
npm install gulp-base64 --save-dev        //- 把小图片转成base64字符串

安装完毕之后,会在项目中生成一个node_moudles目录,所有的插件全部在该目录下。

第三步:构建项目目录结构以及编写项目代码

本例代码只用做测试而已,目录结构以及代码是我随意写的

我的目录结构,如下图:(目录没有全部展开)

目前index.html文件中的css和js的引用路径是这样的,如下图:

其他目录下的html文件也是这样的,都引用的是未压缩和md5命名的css和js文件。

第四步:创建一个gulpfile.js文件,该文件和node_modules文件夹平级

gulpfile.js文件内容如下:

gulpfile.js:

var gulp = require('gulp');
var concat = require('gulp-concat');                //- 多个文件合并为一个;
var minifyCss = require('gulp-minify-css');         //- 压缩CSS文件;
var rev = require('gulp-rev');                      //- 对css、js文件名加MD5后缀
var revCollector = require('gulp-rev-collector');   //- 路径替换
var clean = require('gulp-clean');                  //- 用于删除文件
var uglify = require('gulp-uglify');                //- 压缩js代码
var imagemin = require('gulp-imagemin');            //- 压缩图片
var base64 = require('gulp-base64');                //- 把小图片转成base64字符串
var q = require('q');                               //- 用于解决任务执行顺序的问题(一个任务执行完毕才执行另外一个任务)(暂时还没用到)

/*清理文件*/
gulp.task('clean',function () {                     //删除dist目录下的所有文件
    gulp.src('dist/*',{read:false})
        .pipe(clean());
});

/*压缩js文件,并生成md5后缀的js文件*/
gulp.task('compress-js',function (callback) {       //- 创建一个名为compress-js的task
    gulp.src(['webContent/js/**/*.js'])             //- 需要处理的js文件,放到一个字符串数组里
        .pipe(uglify())                             //- 压缩文件
        .pipe(rev())                                //- 文件名加MD5后缀
        .pipe(gulp.dest('dist/js'))                 //- 另存压缩后的文件
        .pipe(rev.manifest())                       //- 生成一个rev-manifest.json
        .pipe(gulp.dest('rev-js'))                  //- 将rev-manifest.json保存到 rev-js 目录内
        .on('end',function () {
            console.log('compress-js has been completed');
            callback();
        });
});

/*压缩css文件,并生成md5后缀的css文件*/
gulp.task('compress-css', function(callback) {      //- 创建一个名为compress-css的task
    gulp.src(['webContent/css/**/*.css'])           //- 需要处理的css文件,放到一个字符串数组里
        // .pipe(concat('css/wap.min.css'))         //- 合并后的文件名
        .pipe(minifyCss())                          //- 压缩处理成一行
        .pipe(rev())                                //- 文件名加MD5后缀
        .pipe(gulp.dest('dist/css'))                //- 输出文件到dist/css目录下
        .pipe(rev.manifest())                       //- 生成一个rev-manifest.json
        .pipe(gulp.dest('rev-css'))                 //- 将rev-manifest.json保存到rev-css目录内
        .on('end',function () {
            console.log('compress-css has been completed');
            callback();
        });
});

/*修改html文件的link标签和script标签引用的css和js文件名,并把html文件输出到指定的位置*/
gulp.task('rev-html',['compress-css','compress-js'], function() {          //- compress-css和compress-js任务执行完毕再执行rev-index任务
    /*修改index.html文件的link标签和script标签引用的css和js文件名,并把html文件输出到指定的位置*/
    gulp.src(['rev-css/*.json','rev-js/*.json', 'webContent/index.html'])   //- 读取两个rev-manifest.json文件以及需要进行css和js名替换的html文件
        .pipe(revCollector())                                               //- 执行文件内css和js名的替换
        .pipe(gulp.dest('dist/'));                                          //- 替换后的html文件输出的目录

    /*修改其它html文件的link标签和script标签引用的css和js文件名,并把html文件输出到指定的位置*/
    gulp.src(['rev-css/*.json','rev-js/*.json', 'webContent/views/**/*.html'])     //- 读取两个rev-manifest.json文件以及需要进行css和js名替换的html文件
        .pipe(revCollector())                                                      //- 执行文件内css和js名的替换
        .pipe(gulp.dest('dist/views'));                                            //- 替换后的html文件输出的目录
});

/*压缩并复制图片*/
gulp.task('compress-img',function () {
    gulp.src('webContent/images/**/*.*')    //原图片的位置
        .pipe(imagemin())                   //执行图片压缩
        .pipe(gulp.dest('dist/images'));    //压缩后的图片输出的位置
});

/*最终执行的任务-css*/
gulp.task('rev',['rev-html','compress-img']);

//***********************************************************************************************

//命令行顺序: clean, rev

第五步:运行gulp命令

运行如下命令:gulp rev

运行完该命令后会生成以下三个目录:dist、rev-css、rev-js。其中dist目录下就是新的html文件、css文件、js文件和图片,目录和之前的webContent目录下的结构是一样的。

运行完命令后的项目整体结构如下:

WebContent目录的结构和dist目录的结构是一样的,如下:

所有的css和js文件都加了md5命名了,所有的图片体积也小了,但用肉眼看不出来图片质量有变化。

此时dist目录下所有的html文件引用的css和js的引用路径都变成带有md5命名的了。例如index.html,见下图

此时dist目录下的东西就是我们可以上线的文件了。(当然还有很多不完善的地方,还有很多缺陷,毕竟个人知识能力有限。)

第六步:代码的改动

如果后续代码有改动的话,执行一次gulp clean命令,再执行一次gulp rev 命令:

gulp clean命令就可以把dist目录下生成的所有文件全部删除,gulp rev命令会根据新的代码重新生成所有文件到dist目录下。

命令截图如下:

另外本来也想在本例中使用图片转成base64,可是一直没成功解决。如果哪位大神有知道的,还望能在评论区给个链接,让我也学习学习。

说明:由于本人知识有限,才接触gulp不久,只能实现这样一些功能,肯定还有很多不足的地方,还有很多需要不断完善优化的地方以及很多还不知道的功能,。或许在稍微大型一点的项目中也不知会不会出现问题。所有的这一切,包括其他工具的使用等等,都需要后续的继续努力学习。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏偏前端工程师的驿站

Vim杂记:markdown插件

一、安装插件                                 从以下地址下载压缩包   github下载:https://github.com...

210100
来自专栏破晓之歌

关于python项目依赖生成,数据导出和导入 原

它生成的 requirements.txt 文件包含当前环境的完全列表,不相关的依赖包也会包含进来。

12210
来自专栏前端小叙

nodejs的package.json依赖dependencies中 ^ 和 ~ 的区别

nodejs的package.json定义了一个模块,包括其依赖关系的一个简单的JSON文件,该文件可以包含多个不同的指令来告诉Node包管理器如何处理模块。 ...

30290
来自专栏一枝花算不算浪漫

[常见问题]Project facet Java versin 1.8 is not support.

37370
来自专栏Python

linux每日命令(2):cd命令

说明:进入系统根目录,上面命令执行完后拿ls命令看一下,当前目录已经到系统根目录了

13030
来自专栏pangguoming

ubuntu12.04 安装配置jdk1.7

第一步:下载jdk-7-linux-i586.tar.gz wget -c http://download.oracle.com/otn-pub/java/jd...

36350
来自专栏程序员互动联盟

【编程基础】聊聊如何学习Java—Java开发环境配置

之前两篇文章介绍了为什么学习Java和Java语言的特性,很多网友询问如何配置Java开发环境,这一篇我就给大家聊聊如何配置Java环境。 1、下载J...

38290
来自专栏JAVA同学会

nginx的基础应用

今天我们将介绍一些nginx的简单应用,启动、停止nginx,重载nginx的配置,nginx配置文件的格式,如何配置nginx服务静态资源,如何配置nginx...

9720
来自专栏difcareer的技术笔记

编译私有的Android SDK

某些原因需要自己编译一个Android SDK,比如放开某些API接口。本文记录一下编译过程。

7920
来自专栏企鹅号快讯

Python模块知识1:模块知识介绍

模块是代码的归类,能定义函数、类和变量,把相关的代码分配到一个模块里,能让你的代码更好用,更易懂、也更简洁。模块在java中叫做类库。 模块的存在方式: 模块可...

20660

扫码关注云+社区

领取腾讯云代金券