zoukankan      html  css  js  c++  java
  • gulp 添加版本号 解决浏览器缓存问题

    分别安装gulp-rev、gulp-rev-collerctor、gulp-asset-rev,安装了的略过

    npm install gulp-rev --save-dev

    npm install gulp-rev-collerctor --save-dev

    npm install gulp-asset-rev --save-dev

    gulp-asset-rev是处理css图片路径哈希值的

    打开node_modulesgulp-assets-revindex.js

    78行 var verStr = (options.verConnecter || "-") + md5;
    更新为:var verStr = (options.verConnecter || "") + md5;
    80行 src = src.replace(verStr, '').replace(/(.[^.]+)$/, verStr + "$1");
    更新为:src=src+"?v="+verStr;

    //版本号添加修改

    1.打开node_modulesgulp-revindex.js
    
         第144行 manifest[originalFile] = revisionedFile;
        更新为: manifest[originalFile] = originalFile + '?v=' + file.revHash;

    2.打开nodemodulesgulp-rev
    odemodules
    ev-pathindex.js
    
        10行 return filename + '-' + hash + ext;
        更新为: return filename + ext;

     第三步:打开node_modulesgulp-rev-collectorindex.js

    第一处修改为:

    if ( !_.isString(json[key]) || path.basename(json[key]).split('?')[0] !== path.basename(key) ) {
                              isRev = 0;
                      }

     第二处修改为:

    var rp = pattern.replace(/[-[]{}()*+?.^$|/\]/g, "\$&");
        rp = pattern + "(\?v=(\d|[a-z]){8,10})*";
        return rp;

    第三处修改为:

    patterns.push( escPathPattern( (path.dirname(key) === '.' ? '' : closeDirBySep(path.dirname(key)) ) + path.basename(key, path.extname(key)) )
                                + opts.revSuffix
                                + escPathPattern( path.extname(key) ) + "(\?v=(\d|[a-z]){8,10})*"
                            );

    可能因为版本更替,可能行号变了,具体以图为准

    详情见图片 图片为修改后的内容

  • 相关阅读:
    Java实现 LeetCode 173 二叉搜索树迭代器
    PHP array_reverse() 函数
    PHP array_replace_recursive() 函数
    PHP array_replace() 函数
    PHP array_reduce() 函数
    PHP array_rand() 函数
    C# 通配符转正则
    win10 uwp 验证输入 自定义用户控件
    win10 uwp 验证输入 自定义用户控件
    win10 uwp 验证输入 自定义用户控件
  • 原文地址:https://www.cnblogs.com/bruce-gou/p/6923440.html
Copyright © 2011-2022 走看看