zoukankan      html  css  js  c++  java
  • gulp的基本使用

    图片压缩插件使用gulp-smushit,gulp-smushit压缩率比较大,gulp-imagemin 图片压缩插件压缩率不明显。

     见下图压缩率:

    1、gulp安装

    参照gulp官网进行安装:http://www.gulpjs.com.cn/docs/getting-started/

    2、常用的插件

    gulp所有插件地址:http://gulpjs.com/plugins/

    (1)html压缩插件

    插件地址:https://www.npmjs.com/package/gulp-htmlmin/

    (2)sass编译插件

    插件地址:https://www.npmjs.com/package/gulp-sass/

    注意现在是执行2个任务了,同时注意配置好路径

    (3) 图片压缩插件

    gulp-imagemin插件地址:https://www.npmjs.com/package/gulp-imagemin/

    gulp-smushit插件地址:https://www.npmjs.com/package/gulp-smushit/

    (4)css压缩插件

    插件地址:https://www.npmjs.com/package/gulp-clean-css/

    任务配置示例:

    复制代码
    //css压缩任务
    gulp.task('cssmin', function() {
        //过滤掉.min.css文件
        gulp.src(['./css/*.css', '!./css/*.min.css'])
            .pipe(cleanCSS({
                //'ie8':IE8+兼容模式,
                compatibility: 'ie8'
            }))
            .pipe(gulp.dest('./dist/css'));
    });
    复制代码

     (5)JS压缩插件gulp-uglify

    插件地址:https://www.npmjs.com/package/gulp-uglify/

    任务配置示例:

    复制代码
    //JS压缩任务
    gulp.task('jsmin', function() {
        //过滤掉.min.js文件
        gulp.src(['./js/*.js','!./js/*.min.js'])
            .pipe(uglify({
                //支持IE8
                ie8: true
            }))
            .pipe(gulp.dest('./dist/js'));
    });
    复制代码

    (6)雪碧图插件gulp-css-spriter

    插件地址:https://www.npmjs.com/package/gulp-css-spriter/

    在css中只需要这样写即可:

    复制代码
    body{
        margin: 0;
        padding: 0;
         100%;
        height: 100%;
        transform: translate(100px,100px);
    }
    .a{
         71px;
        height: 93px;
        background: url(../img/sqbg-icon.png) no-repeat center;
    }
    .b{
         960px;
        height: 417px;
        background: url(../img/ceshi3.png) no-repeat center;
    }
    复制代码

    生成后的CSS为:

    复制代码
    body {
        margin: 0;
        padding: 0;
         100%;
        height: 100%;
        transform: translate(100px,100px);
    }
    
    .a {
         71px;
        height: 93px;
        background: url(../img/spritesheet.png) no-repeat center;
        background-position: -0px -417px;
    }
    
    .b {
         960px;
        height: 417px;
        background: url(../img/spritesheet.png) no-repeat center;
        background-position: -0px -0px;
    }
    复制代码

    自动将图片路径更换为雪碧图的spritesheet.png的路径,同时自动添加上了background-position

    另外:若不想页面中所有的png都合并为雪碧图,可以将只想合并的图片后添加?__spriter

    示例代码:

    复制代码
    body {
        margin: 0;
        padding: 0;
         100%;
        height: 100%;
        transform: translate(100px, 100px);
    }
    
    .a {
         71px;
        height: 93px;
        background: url(../img/sqbg-icon.png?__spriter) no-repeat center;
    }
    
    .b {
         960px;
        height: 417px;
        background: url(../img/ceshi3.png) no-repeat center;
    }
    
    .c {
         960px;
        height: 417px;
        background: url(../img/product4.png?__spriter) no-repeat center;
    }
    复制代码

    生成后的css代码为:

    复制代码
    body {
        margin: 0;
        padding: 0;
         100%;
        height: 100%;
        transform: translate(100px, 100px);
    }
    
    .a {
         71px;
        height: 93px;
        background: url(../img/spritesheet.png) no-repeat center;
        background-position: -0px -417px;
    }
    
    .b {
         960px;
        height: 417px;
        background: url(../img/ceshi3.png) no-repeat center;
    }
    
    .c {
         960px;
        height: 417px;
        background: url(../img/spritesheet.png) no-repeat center;
        background-position: -0px -0px;
    }
    复制代码

    实现以上情景需要做的是修改 ode_modulesgulp-css-spriterlibmap-over-styles-and-transform-background-image-declarations.js 这个文件的40行开始的if--else if代码块为:

    复制代码
    // background-image always has a url 且判断url是否有?__spriter后缀
    
            if(transformedDeclaration.property === 'background-image' && /?__spriter/i.test(transformedDeclaration.value)) {
    
                transformedDeclaration.value = transformedDeclaration.value.replace('?__spriter', '');
                return cb(transformedDeclaration, declarationIndex, declarations);
            }
            // Background is a shorthand property so make sure `url()` is in there 且判断url是否有?__spriter后缀
            else if(transformedDeclaration.property === 'background' && /?__spriter/i.test(transformedDeclaration.value)) {
    
                transformedDeclaration.value = transformedDeclaration.value.replace('?__spriter', '');
                var hasImageValue = spriterUtil.backgroundURLRegex.test(transformedDeclaration.value);
    
                if(hasImageValue) {
                    return cb(transformedDeclaration, declarationIndex, declarations);
                }
            }
    复制代码

    如下截图:

    (7)JS代码检查插件gulp-jshint

    插件地址:https://www.npmjs.com/package/gulp-jshint/

    同时安装jshint-stylish插件,插件地址:https://www.npmjs.com/package/tslint-stylish/

    错误和警告输出为一下形式:

     (8)重命名插件gulp-rename

    插件地址:https://www.npmjs.com/package/gulp-rename/

     配置文件示例:

    复制代码
    gulp.task('jsmin', function() {
        //过滤掉.min.js文件
        gulp.src(['./js/*.js', '!./js/*.min.js'])
            .pipe(uglify({
                //支持IE8
                ie8: true
            }))
            //修改扩展名
            .pipe(rename({suffix: '.min'}))
            .pipe(gulp.dest('./dist/js'));
    });
    复制代码

     (8)资源、模块复用插件gulp-file-include

    插件地址:https://www.npmjs.com/package/gulp-file-include

    (9)自动添加前缀gulp-autoprefixer

    插件地址:https://www.npmjs.com/package/gulp-autoprefixer

    以上插件组合后的整体配置文件(包含命令的顺序执行),在命令行中直接输入gulp执行即可: 

    复制代码
    var gulp = require('gulp');
    //HTML压缩插件
    var htmlmin = require('gulp-htmlmin');
    //SASS编译插件
    var sass = require('gulp-sass');
    //图片压缩插件
    var imagemin = require('gulp-imagemin');
    //PNG压缩插件
    var imageminPngquant = require('imagemin-pngquant');
    //CSS压缩插件
    var cleanCSS = require('gulp-clean-css');
    //雪碧图合并插件
    var spriter = require('gulp-css-spriter');
    //js压缩插件
    var uglify = require('gulp-uglify');
    //添加前缀插件
    var autoprefixer = require('gulp-autoprefixer');
    //图片压缩插件
    var smushit = require('gulp-smushit');
    //js校验插件
    var jshint = require('gulp-jshint');
    //重命名插件
    var rename = require("gulp-rename");
    //图片压缩中减少重复压缩
    var cache = require('gulp-cache');
    //模板复用
    var fileinclude = require('gulp-file-include');
    
    //html压缩任务
    gulp.task('html', function() {
        return gulp.src('./*.html')
            //资源复用插件
            .pipe(fileinclude({
                prefix: '@@',
                basepath: '@file'
            }))
            //html压缩插件
            .pipe(htmlmin({
                collapseWhitespace: true
            }))
            .pipe(gulp.dest('./dist'))
    });
    
    //sass编译任务--包括scss编译、雪碧图合并、添加前缀、压缩和重命名任务
    gulp.task('sass', function() {
        return gulp.src('./css/*.scss')
            .pipe(sass().on('error', sass.logError))
            //雪碧图合并
            .pipe(spriter({
                //这是雪碧合成的图
                'spriteSheet': './dist/img/scssSpriteSheet.png',
                //css引用的图片路径
                'pathToSpriteSheetFromCSS': '../img/scssSpriteSheet.png'
            }))
            //添加前缀
            .pipe(autoprefixer({
                //浏览器市场占有率参考:https://mtj.baidu.com/data/mobile/device 以及http://tongji.baidu.com/data/browser
                //配置参考:https://github.com/postcss/autoprefixer
                browsers: ['> 1%', 'ie >= 8', 'Android >= 4.1', 'iOS >= 7.0'],
                //是否美化属性值 默认:true 像这样:
                //-webkit-transform: rotate(45deg);
                //        transform: rotate(45deg);
                cascade: false
            }))
            //css压缩
            .pipe(cleanCSS({
                //'ie8':IE8+兼容模式,
                compatibility: 'ie8'
            }))
            //修改扩展名
            .pipe(rename({
                suffix: '.min'
            }))
            .pipe(gulp.dest('./dist/css'));
    });
    
    //监控文件任务
    gulp.task('watch', function() {
        //监控 scss 文件,如果有修改,则执行 sass 任务
        gulp.watch('./css/*.scss', ['sass']);
        //监控 js 文件,如果有修改,则执行 scripts 任务
        gulp.watch('./js/*.js', ['scripts']);
        //监控 css 文件,如果有修改,则执行 css 任务
        gulp.watch('./css/*.css', ['css']);
        //监控 图片 文件,如果有修改,则执行 imagemin 任务
        gulp.watch('./img/*.{jpg,png}', ['imagemin']);
        //监控 图片 文件,如果有修改,则执行 imagemin 任务
        gulp.watch('./*.html', ['html']);
    
    });
    
    //图片压缩任务--使用gulp-imagemin插件
    //gulp.task('imagemin', function() {
    //    gulp.src('./img/*')
    //        .pipe(imagemin({
    //            progressive: true,
    //            svgoPlugins: [{
    //                removeViewBox: false
    //            }], //不要移除svg的viewbox属性
    //            use: [imageminPngquant()] //使用pngquant深度压缩png图片的imagemin插件
    //        }))
    //        .pipe(gulp.dest('dist/img'))
    //});
    
    //更改压缩插件使用gulp-smushit
    gulp.task('imagemin', function() {
        return gulp.src('./img/*.{jpg,png}')
            .pipe(cache(smushit({
                //显示压缩率
                verbose: true
            })))
            .pipe(gulp.dest('dist/img'));
    });
    
    //css任务--雪碧图合并、添加前缀、压缩、重命名
    gulp.task('css', function() {
        //过滤掉.min.css文件
        return gulp.src(['./css/*.css', '!./css/*.min.css'])
            //雪碧图合并
            .pipe(spriter({
                //这是雪碧合成的图
                'spriteSheet': './dist/img/spritesheet.png',
                //css引用的图片路径
                'pathToSpriteSheetFromCSS': '../img/spritesheet.png'
            }))
            //添加前缀
            .pipe(autoprefixer({
                //浏览器市场占有率参考:https://mtj.baidu.com/data/mobile/device 以及http://tongji.baidu.com/data/browser
                //配置参考:https://github.com/postcss/autoprefixer
                browsers: ['> 1%', 'ie >= 8', 'Android >= 4.1', 'iOS >= 7.0'],
                //是否美化属性值 默认:true 像这样:
                //-webkit-transform: rotate(45deg);
                //        transform: rotate(45deg);
                cascade: false
            }))
            //css压缩
            .pipe(cleanCSS({
                //'ie8':IE8+兼容模式,
                compatibility: 'ie8'
            }))
            //修改扩展名
            .pipe(rename({
                suffix: '.min'
            }))
            .pipe(gulp.dest('./dist/css'));
    });
    
    //scripts任务--包含压缩和重命名
    gulp.task('scripts', function() {
        //过滤掉.min.js文件
        return gulp.src(['./js/*.js', '!./js/*.min.js'])
            .pipe(uglify({
                //支持IE8
                ie8: true
            }))
            //修改扩展名
            .pipe(rename({
                suffix: '.min'
            }))
            .pipe(gulp.dest('./dist/js'));
    });
    
    //js校验任务--jshint
    gulp.task('lint', function() {
        return gulp.src('./js/*.js')
            .pipe(jshint())
            //使用了tslint-stylish插件
            .pipe(jshint.reporter("jshint-stylish"));
    });
    
    //串行方式运行任务:做好依赖
    gulp.task('default', ['sass', 'css', 'scripts', 'imagemin', 'html', 'watch']);
    复制代码

     说明:

    (1)gulp的排除模式:

    // 使用数组的方式来匹配多种文件
    gulp.src(['*.js','!b*.js']) // 匹配所有js文件,但排除掉以b开头的js文件
    gulp.src(['!b*.js',*.js]) // 不会排除任何文件,因为排除模式不能出现在数组的第一个元素中

    (2)gulp 对于 one after one 的任务链,需要加 return

    注意:

    (1)配置好文件路径。

    (2)安装相关插件 npm i 插件名 --save-dev

    以上插件的安装命令为:

    npm install --save-dev gulp
    npm install gulp-htmlmin --save-dev
    npm install gulp-sass --save-dev
    npm install gulp-clean-css --save-dev
    npm install gulp-css-spriter --save-dev
    npm install gulp-uglify --save-dev
    npm install gulp-autoprefixer --save-dev
    npm install gulp-smushit --save-dev
    npm install gulp-jshint --save-dev
    npm install gulp-rename --save-dev
    npm install gulp-cache --save-dev
    npm install gulp-file-include --save-dev

    (3)所有的文件命名不能出现中文字符

    (3)gulp的版本管理:

      1.打开 模块位置/node_modules/gulp-rev/index.js

    修改134行 manifest[originalFile] = revisionedFile;

    改为 manifest[originalFile] = originalFile + '?v=' + file.revHash;

           2.打开 模块位置/node_modules/rev-path/index.js

    修改10行 return filename + '-' + hash + ext;

    更新为: return filename + ext;

           3.打开 模块位置/node_modules/gulp-rev-collector/index.js

    修改40行 let cleanReplacement = path.basename(json[key]).replace(new RegExp( opts.revSuffix ), '' );

    更新为:let cleanReplacement = path.basename(json[key]).replace(new RegExp( opts.revSuffix ), '' ).split('?')[0];

    修改163行 regexp: new RegExp( prefixDelim + pattern, 'g' ),

    修改为: regexp: new RegExp( prefixDelim + pattern + '(\?v=\w{10})?', 'g' ),

      4.打开 模块位置/node_modules/gulp-asset-rev/index.js

    修改78~80行:var verStr = (options.verConnecter || "-") + md5;

    src = src.replace(verStr, '').replace(/(.[^.]+)$/, verStr + "$1");

    改为:var verStr = (options.verConnecter || "") + md5;

    src = src + "?v=" + verStr;

  • 相关阅读:
    struts 简单配置运用做一个简单的注册
    hibernate 锁 (转)
    Hibernate 缓存机制(转)
    解决Hibernate:could not initialize proxy
    el 表达式用法(转)
    自动生成Hibernate框架结构
    封装hibernate 初始化类 方便调用 (静态单例模式)
    构建hibernate 框架实现增删改查功能
    JSON 与 对象 、集合 之间的转换(转)
    Ajax 引擎 传输数据的方法
  • 原文地址:https://www.cnblogs.com/lifeng666/p/11541776.html
Copyright © 2011-2022 走看看