Gulp3 项目压缩


本篇文章介绍gulp3版本压缩步骤,过程中遇到的问题会在下篇博客中总结。如果不知道本地安装的gulp版本可以使用命令 gulp -v 查看。另外还可访问gulp官网 https://www.gulpjs.com.cn/ ,不过中文官网个人感觉没啥有用的东西,遇到问题还是百度靠谱一点。

构建打包

因为是对打包后的文件进行压缩,所以需要先ng build 进行打包

压缩

全局安装gulp

cnpm install gulp -g

本地安装gulp

cnpm install gulp -save

全局安装gulp是为了执行gulp任务,本地安装是为了调用gulp插件的功能。

本地安装gulp插件

cnpm install gulp-uglify      //压缩js文件
cnpm install gulp-imagemin      //压缩图片
cnpm install gulp-htmlmin        //压缩HTML
cnpm install gulp-clean-css      //压缩css

新建gulpfile.js文件----核心代码

将以下代码放入js文件中(此文件中dist代表打包后生成的文件名称

gulp = require('gulp'),
uglify = require('gulp-uglify'),
imagemin = require('gulp-imagemin'),
htmlmin = require('gulp-htmlmin'),
cssmin = require('gulp-clean-css');
// ----------------------------------------html压缩--------------------
gulp.task('testHtmlmin', function () {
var options = {
    removeComments: true,//清除HTML注释
    collapseWhitespace: true//压缩HTML
};
gulp.src('dist/*.html')
    .pipe(htmlmin(options))
    .pipe(gulp.dest('dist'));
});

gulp.task('testAssetsHtmlmin', function () {
var options = {
    removeComments: true,//清除HTML注释
    collapseWhitespace: true//压缩HTML
};
gulp.src('dist/assets/fonts/*.html')
    .pipe(htmlmin(options))
    .pipe(gulp.dest('dist/assets/fonts'));
});
// ------------------------------------------HTML压缩-------------end--

// -------------------------------------------JS压缩-------------------
gulp.task('testJS', function () {
gulp.src('dist/*.js') //多个文件以数组形式传入
    .pipe(uglify())
    .pipe(gulp.dest('dist'));
});

gulp.task('testAssets', function () {
gulp.src('dist/assets/*.js') //多个文件以数组形式传入
    .pipe(uglify())
    .pipe(gulp.dest('dist/assets'));
});

gulp.task('testAssetsJS', function () {
gulp.src('dist/assets/js/*.js') //多个文件以数组形式传入
    .pipe(uglify())
    .pipe(gulp.dest('dist/assets/js'));
});

gulp.task('testFontJS', function () {
gulp.src('dist/assets/fonts/*.js') //多个文件以数组形式传入
    .pipe(uglify())
    .pipe(gulp.dest('dist/assets/fonts'));
});
// ---------------------------------------------JS压缩----------end----

// ---------------------------------------------image图片压缩-----------
gulp.task('testImagemin', function () {
gulp.src('dist/*.{png,jpg,gif,ico}')
    .pipe(imagemin({
        optimizationLevel: 5, //类型:Number  默认:3  取值范围:0-7(优化等级)
        progressive: true, //类型:Boolean 默认:false 无损压缩jpg图片
        interlaced: true, //类型:Boolean 默认:false 隔行扫描gif进行渲染
        multipass: true //类型:Boolean 默认:false 多次优化svg直到完全优化
    }))
    .pipe(gulp.dest('dist'));
});
gulp.task('Imagemin', function () {
gulp.src('dist/assets/images/*.{png,jpg,gif,ico}')
    .pipe(imagemin({
        optimizationLevel: 5, //类型:Number  默认:3  取值范围:0-7(优化等级)
        progressive: true, //类型:Boolean 默认:false 无损压缩jpg图片
        interlaced: true, //类型:Boolean 默认:false 隔行扫描gif进行渲染
        multipass: true //类型:Boolean 默认:false 多次优化svg直到完全优化
    }))
    .pipe(gulp.dest('dist/assets/images'));
}); 
// -------------------------------------image图片压缩----------end------

// -------------------------------------css压缩------------------------
gulp.task('testCss', function () {
gulp.src('dist/*.css')
    .pipe(cssmin({
        advanced: false,//类型:Boolean 默认:true [是否开启高级优化(合并选择器等)]
        compatibility: 'ie7',//保留ie7及以下兼容写法 类型:String 默认:''or'*' [启用兼容模式; 'ie7':IE7兼容模式,'ie8':IE8兼容模式,'*':IE9+兼容模式]
        keepBreaks: true,//类型:Boolean 默认:false [是否保留换行]
        keepSpecialComments: '*'
        //保留所有特殊前缀 当你用autoprefixer生成的浏览器前缀,如果不加这个参数,有可能将会删除你的部分前缀
    }))
    .pipe(gulp.dest('dist'));
});
gulp.task('testCssmin', function () {
gulp.src('dist/assets/css/*.css')
    .pipe(cssmin({
        advanced: false,//类型:Boolean 默认:true [是否开启高级优化(合并选择器等)]
        compatibility: 'ie7',//保留ie7及以下兼容写法 类型:String 默认:''or'*' [启用兼容模式; 'ie7':IE7兼容模式,'ie8':IE8兼容模式,'*':IE9+兼容模式]
        keepBreaks: true,//类型:Boolean 默认:false [是否保留换行]
        keepSpecialComments: '*'
        //保留所有特殊前缀 当你用autoprefixer生成的浏览器前缀,如果不加这个参数,有可能将会删除你的部分前缀
    }))
    .pipe(gulp.dest('dist/assets/css'));
});
gulp.task('testFontCssmin', function () {
gulp.src('dist/assets/fonts/*.css')
    .pipe(cssmin({
        advanced: false,//类型:Boolean 默认:true [是否开启高级优化(合并选择器等)]
        compatibility: 'ie7',//保留ie7及以下兼容写法 类型:String 默认:''or'*' [启用兼容模式; 'ie7':IE7兼容模式,'ie8':IE8兼容模式,'*':IE9+兼容模式]
        keepBreaks: true,//类型:Boolean 默认:false [是否保留换行]
        keepSpecialComments: '*'
        //保留所有特殊前缀 当你用autoprefixer生成的浏览器前缀,如果不加这个参数,有可能将会删除你的部分前缀
    }))
    .pipe(gulp.dest('dist/assets/fonts'));
});
// --------------------------------------css压缩---------end-----------

执行gulp任务

gulp testJS
gulp testAssets
gulp testImagemin
gulp testCssmin
gulp testHtmlmin

结果展示

压缩前
在这里插入图片描述
压缩后
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值