gulp 版本號修改

默認效果:

<link rel="stylesheet" href="css/app-803a7fe4ae.css">
<script src="js/app-3a0d844594.js"></script>
期望效果

<link rel="stylesheet" href="css/app.css?v=803a7fe4ae">
<script src="js/app.js?v=3a0d844594"></script>
 

 

爲了將 gulp-rev + gulp-rev-collector 添加版本號後的默認效果修改爲預期效果,需作如下修改:

1.打開node_modules\gulp-rev\index.js
manifest[originalFile] = revisionedFile;
更改爲: 
manifest[originalFile] = originalFile + '?v=' + file.revHash;
 
2.打開nodemodules\rev-path\index.js
return filename + '-' + hash + ext;
更改爲: 
return filename + ext;
 
3.打開node_modules\gulp-rev-collector\index.js
if ( !_.isString(json[key]) || path.basename(json[key]).replace(new RegExp( opts.revSuffix ), '' ) !== path.basename(key) ) { 
更改爲: 
if ( !_.isString(json[key]) || path.basename(json[key]).split('?')[0] !== path.basename(key) ) {
regexp: new RegExp( '([\/\\\\\'"])' + pattern, 'g' ),
更改爲: 
regexp: new RegExp( '([\/\\\\\'"])' + pattern+'(\\?v=\\w{10})?', 'g' ),
(如果該文件查找不到
if ( !_.isString(json[key]) || path.basename(json[key]).replace(new RegExp( opts.revSuffix ), '' ) !== path.basename(key) ) {

if ( !_.isString(json[key]) || path.basename(json[key]).replace(new RegExp( opts.revSuffix ), '' ) !== path.basename(key) ) {
則把index.js替換

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章