使用grunt来无损压缩图片

作为一个前端工程师,或者web开发工程师,图片是你无法忽视的一个东西,没有一本优化方面的书不会提及图片的优化。

pagespeed里面,首当其冲的也是提示你的图片需要优化。

之前有做过很多尝试,处理png图片等,可以查看以前的博客:优化png图片的历程


但是之前的方法有两个问题:

1、主要是优化PNG图片

2、效率低下,不适合批量操作


为了解决上诉问题,现在使用一个新的方法去批量压缩图片。

这个方法就是,噔噔噔噔,Grunt-contrib-imagemin

操作步骤如下:


1、首先你得有nodejs环境,如果你没有,请参考:https://nodejs.org/

2、然后打开node.js command prompt

3、通过npm安装grunt,如果你没有grunt的话。要安装,请参考:http://www.gruntjs.net/

4、然后新建一个文件夹,我的个人看法是,你所新建的这个文件夹将作为你压缩图片的一个寄存地,也就是一个缓存区。当你要压缩某些图片的时候,可以把图片复制过来,然后运行一下压缩命令即可。而不用每次都在你的项目目录中安装imagemin


安装Grunt-contrib-imagemin,需要系统中已经安装grunt的,所以你首先要参考第3条。


输入了安装imagemin的命令后,会从远程服务器中下载这个包到你的新建的目录中了。

5、新建Gruntfile.js文件,打开你刚才新建的目录,我这里是gruntImgmin

然后在这个根目录中,新建上述js文件,然后新建grunt任务:

module.exports = function (grunt) {
    'use strict';
    grunt.initConfig({
        imagemin: {
            /* 压缩图片大小 */
            dist: {
                options: {
                    optimizationLevel: 3 //定义 PNG 图片优化水平
                },
                files: [
                       {
                    expand: true,
                    cwd: 'images/',
                    src: ['**/*.{png,jpg,jpeg}'], // 优化 img 目录下所有 png/jpg/jpeg 图片
                    dest: 'images/' // 优化后的图片保存位置,覆盖旧图片,并且不作提示
                    }
                    ]
                }
            },
            });
    grunt.loadNpmTasks('grunt-contrib-imagemin');
    grunt.registerTask('img', ['imagemin']);
};

上面的任务中,我是把原图片文件夹和目标文件夹写成了同一个,也就是要覆盖原图片,如果你不想这样,可以自己更改路径就可以了。



6、把图片放在相应的文件夹之后,在nodejs的命令行中输入命令:



7、文件对比

压缩前总文件大小为535k,压缩后为508k,减少了47k。

因为压缩的图片大部分为jpg,所以压缩率可能不是特别高,当png比较多,或者整体文件比较多的时候,这种差异会更大。减少了47k已经减少了很多,为你的网页的性能呢个又优化了一步。



参考:

http://www.zfanw.com/blog/gruntjs-optimize-image-size-loseless.html

http://www.gruntjs.net/

https://nodejs.org/



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值