gulp压缩整站方法(htmlcssjsimage)

JavaScript013

gulp压缩整站方法(htmlcssjsimage),第1张

注入package.json(此json文件需要自己在当前项目目录下创建即可--不能有注释)安装:

npm install gulp-uglify --save-dev

全局安装:

npm install gulp-uglify -g

整站静态文件压缩配置文件gulpfile.js(html/css/image/js前提是安装下列require用到的模块):

var gulp = require('gulp'),//基础库

    htmlmin = require('gulp-htmlmin'),//html压缩

cssmin = require('gulp-minify-css'),//css压缩

jshint = require('gulp-jshint'),//js检查

uglify = require('gulp-uglify'),//js压缩

imagemin = require('gulp-imagemin'),//图片压缩

    pngquant = require('imagemin-pngquant'),//图片深入压缩

imageminOptipng = require('imagemin-optipng'),

    imageminSvgo = require('imagemin-svgo'),

    imageminGifsicle = require('imagemin-gifsicle'),

    imageminJpegtran = require('imagemin-jpegtran'),

domSrc = require('gulp-dom-src'),

cheerio = require('gulp-cheerio'),

processhtml = require('gulp-processhtml'),

Replace = require('gulp-replace'),

cache = require('gulp-cache'),//图片压缩缓存

clean = require('gulp-clean'),//清空文件夹

conCat = require('gulp-concat'),//文件合并

plumber=require('gulp-plumber'),//检测错误

gutil=require('gulp-util')//如果有自定义方法,会用到

var date = new Date().getTime()

gulp.task('clean',function(){

return gulp.src('min/**',{read:false})

.pipe(clean())

})

function errrHandler( e ){

    // 控制台发声,错误时beep一下

    gutil.beep()

    gutil.log(e)

this.emit('end')

}

gulp.task('cleanCash', function (done) {//清除缓存

    return cache.clearAll(done)

})

gulp.task('htmlmin', function () {

    var options = {

        removeComments: true,//清除HTML注释

        collapseWhitespace: true,//压缩HTML

        collapseBooleanAttributes: false,//省略布尔属性的值 <input checked="true"/>==><input />

        removeEmptyAttributes: false,//删除所有空格作属性值 <input id="" />==><input />

        removeScriptTypeAttributes: true,//删除<script>的type="text/javascript"

        removeStyleLinkTypeAttributes: true,//删除<style>和<link>的type="text/css"

        minifyJS: true,//压缩页面JS

        minifyCSS: true//压缩页面CSS

    }

    gulp.src(['index/*.htm','index/*.html'])

.pipe(plumber({errorHandler:errrHandler}))

.pipe(Replace(/_VERSION_/gi, date))

.pipe(processhtml())

        .pipe(htmlmin(options))

        .pipe(gulp.dest('min'))

})

gulp.task('cssmin', function(){

    gulp.src('index/**/*.css')

.pipe(conCat('css/index.min.css'))

.pipe(plumber({errorHandler:errrHandler}))

        .pipe(cssmin({

            advanced: false,//类型:Boolean 默认:true [是否开启高级优化(合并选择器等)]

            compatibility: 'ie7',//保留ie7及以下兼容写法 类型:String 默认:''or'*' [启用兼容模式; 'ie7':IE7兼容模式,'ie8':IE8兼容模式,'*':IE9+兼容模式]

            keepBreaks: false,//类型:Boolean 默认:false [是否保留换行]

            keepSpecialComments: '*'

            //保留所有特殊前缀 当你用autoprefixer生成的浏览器前缀,如果不加这个参数,有可能将会删除你的部分前缀

        }))

        .pipe(gulp.dest('min'))

})

gulp.task('jsmin', function () {

    gulp.src(['index/js/*.js','!index/**/{text1,text2}.js'])

.pipe(conCat('js/index.min.js'))

.pipe(plumber({errorHandler:errrHandler}))

        .pipe(uglify({

            mangle: {except: ['require' ,'exports' ,'module' ,'$']},//类型:Boolean 默认:true 是否修改变量名

            compress: true,//类型:Boolean 默认:true 是否完全压缩

            preserveComments: 'false' //保留所有注释

        }))

        .pipe(gulp.dest('min'))

}) 

gulp.task('imagemin', function () {

    gulp.src('index/**/*.{png,jpg,gif,ico}')

.pipe(plumber({errorHandler:errrHandler}))

        .pipe(cache(imagemin({

            progressive: true, //类型:Boolean 默认:false 无损压缩jpg图片         

svgoPlugins: [{removeViewBox: false}],//不要移除svg的viewbox属性

            use: [pngquant(),imageminJpegtran({progressive: true})

            , imageminGifsicle({interlaced: true}),imageminOptipng({optimizationLevel:3}), imageminSvgo()] //使用pngquant深度压缩png图片的imagemin插件         

        })))

        .pipe(gulp.dest('min'))

})

gulp.task('default',['clean'],function(){

gulp.start('cssmin','htmlmin','jsmin','imagemin')

})

package.json(例子) package.json详细介绍:https://docs.npmjs.com/files/package.json

(package.json  npm init 命令行创建文件方法http://blog.csdn.net/liyanhui1001/article/details/44020235 )

{

  "name": "web",

  "version": "1.0.0",

  "description": "my text",

  "main": "gulpfile.js",

  "dependencies": {

    "gulp": "^3.9.1",

    "gulp-cache": "^0.4.5",

    "gulp-concat": "^2.6.0",

    "gulp-htmlmin": "^2.0.0",

    "gulp-imagemin": "^3.0.1",

    "gulp-jshint": "^2.0.1",

    "gulp-minify-css": "^1.2.4",

    "gulp-plumber": "^1.1.0",

    "gulp-uglify": "^1.5.4",

    "gulp-util": "^3.0.7",

    "imagemin-pngquant": "^5.0.0",

    "jshint": "^2.9.2",

    "gulp-clean": "^0.3.2"

  },

  "devDependencies": {

    "gulp-cheerio": "^0.6.2",

    "gulp-dom-src": "^0.2.0",

    "gulp-jslint": "^1.0.1",

    "gulp-processhtml": "^1.1.0",

    "gulp-rename": "^1.2.2",

    "gulp-replace": "^0.5.4",

    "gulp-webpack": "^1.5.0",

    "imagemin-gifsicle": "^5.1.0",

    "imagemin-jpegtran": "^5.0.2",

    "imagemin-optipng": "^5.1.1",

    "imagemin-svgo": "^5.1.0",

    "webpack": "^1.13.1"

  },

  "scripts": {

    "test": "echo \"Error: no test specified\" &&exit 1"

  },

  "keywords": [

    "web"

  ],

  "author": "yl",

  "license": "ISC"

}

devDependencies里的内容即为你安装gulp的模块插件名称和版本号!

最后,node.js里指定到当前项目目录下输入gulp命令即可:

gulp default

/步骤

首先要确保pc装nodeglobal环境项目文件都install gulp

npm install gulp -g (global环境)

npm install gulp --save-dev (项目环境)

项目install需要gulp插件般压缩需要

npm install gulp-minify-css gulp-concat gulp-uglify gulp-rename del --save-dev

更插件链接找

项目根目录新建gulpfile.jsrequire需要module

var gulp = require('gulp'),

minifycss = require('gulp-minify-css'),

concat = require('gulp-concat'),

uglify = require('gulp-uglify'),

rename = require('gulp-rename'),

del = require('del')

压缩css

gulp.task('minifycss', function() {

return gulp.src('src/*.css') //压缩文件

.pipe(gulp.dest('minified/css')) //输文件夹

.pipe(minifycss())//执行压缩

})

压缩js

gulp.task('minifyjs', function() {

return gulp.src('src/*.js')

.pipe(concat('main.js')) //合并所jsmain.js

.pipe(gulp.dest('minified/js')) //输main.js文件夹

.pipe(rename({suffix: '.min'})) //rename压缩文件名

.pipe(uglify()) //压缩

.pipe(gulp.dest('minified/js'))//输

})

执行压缩前先删除文件夹内容

gulp.task('clean', function(cb) {

del(['minified/css', 'minified/js'], cb)

})

默认命令cmd输入gulp执行命令

gulp.task('default', ['clean'], function() {

gulp.start('minifycss', 'minifyjs')

})

要cmd执行gulp即

记录一下用 gulp 来合并、压缩CSS以及进行 MD5命名以及替换文件中引入的CSS文件,当然这一系列操作都是用基于gulp插件的,主要会用到下面的几个插件:

var concat = require('gulp-concat')//- 多个文件合并为一个;var minifyCss = require('gulp-minify-css')//- 压缩CSS为一行; var rev = require('gulp-rev')//- 对文件名加MD5后缀var revCollector = require('gulp-rev-collector')//- 路径替换

安装Gulp插件到本地项目

npm init//- 生成一个 package.json,里面是一些常规的配置信息npm install gulp gulp-concat gulp-minify-css gulp-rev gulp-rev-collector --save-dev//- 安装插件到项目目录内

完成上面两步后,会在我们的项目内生成一个package.json文件以及一个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') //- 对文件名加MD5后缀var revCollector = require('gulp-rev-collector') //- 路径替换gulp.task('concat', function() {//- 创建一个名为 concat 的 task

gulp.src(['./css/wap_v3.1.css', './css/wap_v3.1.3.css'])//- 需要处理的css文件,放到一个字符串数组里

.pipe(concat('wap.min.css'))//- 合并后的文件名

.pipe(minifyCss()) //- 压缩处理成一行

.pipe(rev())//- 文件名加MD5后缀

.pipe(gulp.dest('./css')) //- 输出文件本地

.pipe(rev.manifest()) //- 生成一个rev-manifest.json

.pipe(gulp.dest('./rev')) //- 将 rev-manifest.json 保存到 rev 目录内})

gulp.task('rev', function() {

gulp.src(['./rev/*.json', './application/**/header.php']) //- 读取 rev-manifest.json 文件以及需要进行css名替换的文件

.pipe(revCollector()) //- 执行文件内css名的替换

.pipe(gulp.dest('./application/'))//- 替换后的文件输出的目录})

gulp.task('default', ['concat', 'rev'])

运行结果

通过以上的配置之后,就可以开始运行 gulp 对我们的项目进行相关的操作啦;

使用 gulp 命令,运行Gulp.js 构建程序

首先运行 concat 这个 task 生成一个 rev-manifest.json 文件

然后再运行 rev 这个 task 替换掉文件中引入的 css

YuanWingdeMacBook-Pro:m YuanWing$ gulp concat

[11:47:02] Using gulpfile ~/SVN/JKD/m/gulpfile.js

[11:47:03] Starting 'concat'...

[11:47:03] Finished 'concat' after 12 msYuanWingdeMacBook-Pro:m YuanWing$ gulp rev

[11:47:17] Using gulpfile ~/SVN/JKD/m/gulpfile.js

[11:47:17] Starting 'rev'...

[11:47:17] Finished 'rev' after 10 msYuanWingdeMacBook-Pro:m YuanWing$

rev-manifest.json文件内容:

{ "wap.min.css": "wap.min-c49f62a273.css"}

header.php替换前后对比:

替换前:<link rel="stylesheet" href="/css/wap.min.css" />

替换后:<link rel="stylesheet" href="/css/wap.min-c49f62a273.css" />

gulp-rev-collector进行文件路径替换是依据 rev-manifest.json 的,所以要先成生 .json 文件,然后再进行替换;