zoukankan      html  css  js  c++  java
  • gulp自动化压缩合并、加版本号解决方案

    虽然网上有很多的 gulp 构建文章,但是很多都已经随着 gulp 插件的更新无法运行了。因此,我写了这个比较简单的构建方案。

    如果还不熟悉 gulp 的插件,可以阅读上一篇文章:精通gulp常用插件

    这个方案主要是为了实现js/css的压缩合并、自动添加版本号和压缩html。

    • gulp-csso 压缩优化css
    • gulp-uglify 压缩js
    • gulp-html-minify 压缩html
    • gulp-rev-all 生成版本号

    主要通过上面插件实现功能,其他插件配合使用。

    // gulpfile.js
    var gulp = require('gulp'),
        htmlmini = require('gulp-html-minify'),
        useref = require('gulp-useref'),
        uglify = require('gulp-uglify'),
        csso = require('gulp-csso'),
        filter = require('gulp-filter'),
        RevAll = require('gulp-rev-all'),
        del = require('del');
    
    gulp.task('default',['del'], function () {
        var jsFilter = filter('**/*.js',{restore:true}),
            cssFilter = filter('**/*.css',{restore:true}),
            htmlFilter = filter(['**/*.html'],{restore:true});
        gulp.src('/*.html')
            .pipe(useref())                         // 解析html中的构建块
            .pipe(jsFilter)                         // 过滤所有js
            .pipe(uglify())                         // 压缩js
            .pipe(jsFilter.restore)
            .pipe(cssFilter)                        // 过滤所有css
            .pipe(csso())                           // 压缩优化css
            .pipe(cssFilter.restore)
            .pipe(RevAll.revision({                 // 生成版本号
                dontRenameFile: ['.html'],          // 不给 html 文件添加版本号
                dontUpdateReference: ['.html']      // 不给文件里链接的html加版本号
            }))
            .pipe(htmlFilter)                       // 过滤所有html
            .pipe(htmlmini())                       // 压缩html
            .pipe(htmlFilter.restore)
            .pipe(gulp.dest('/dist'))
    })
    
    gulp.task('del',function () {
        del('/dist');                               // 构建前先删除dist文件里的旧版本
    })
    

    在html中,我们需要先定义好构建块。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>gulp自动化构建解决方案</title>
        <!-- build:css static/css/index.css -->     // 定义了构建后引用的css路径
        <link rel="stylesheet" href="static/css/common.css"/>
        <link rel="stylesheet" href="static/css/index.css"/>
        <!-- endbuild -->
    </head>
    <body>
        ......
        
        <!-- build:js static/js/index.js -->        // 定义了构建后引用的js路径
        <script src="static/js/jquery.js"></script>
        <script src="static/js/common.js"></script>
        <script src="static/js/index.js"></script>
        <!-- endbuild -->
    </body>
    </html>
    


    执行构建完成后,会生成 dist 文件夹,目录为:

    |-dist
    |   |-static
    |       |-css
    |           |-index.96cf44da.css
    |       |-js
    |           |-index.42ce3282.js
    |   |-index.html
    

    构建完的index.html,我们忽略压缩的html,完成了压缩合并添加版本号等功能。

    // dist/index.html
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>gulp自动化构建解决方案</title>
        <link rel="stylesheet" href="static/css/index.96cf44da.css"/>
    </head>
    <body>
        ......
    
        <script src="static/js/index.42ce3282.js"></script>
    </body>
    </html>
  • 相关阅读:
    ORACLE CASE WHEN 及 SELECT CASE WHEN的用法
    Oracle中NVARCHAR2字符集不匹配问题
    数据库读写分离
    oracle存储过程获取异常信息码和异常信息
    js删除字符串的最后一个字符三种方法
    我弄的一些TASKER配置
    分享我用Taker做任务时需要的各种资源的精华帖,方便查阅
    Tasker 正则表达式测试器
    支持Tasker控制的app合集
    Tasker文件夹说明
  • 原文地址:https://www.cnblogs.com/gopark/p/8253777.html
Copyright © 2011-2022 走看看