markdown编辑器,gulp为html页面添加版本号,在内容更新之后
不知道各位同学在web开发中是否遇到这样的困扰
在我们更新了JS和CSS等文件后,由于谷歌浏览器的缓存(其他浏览器应该也是这尿性),导致服务器上的JS,CSS文件不能及时更新.
这时我的做法右键查看网页源代码,打开相应的JS,CSS文件,然后刷新,这样就能更新代码,但是这样很影响用户体验,我们总不能每次更新脚本后告诉用户这样去刷新。
怎么解决这个问题呢,曾经想过用php获取svn当前的版本号,然后追加到js后边。类似这样index.js?v=,但是实际操作有些麻烦,而且感觉不太专业。
遂google解决方案,下面就请出今天的主角。[gulp](http://www.gulpjs.com.cn/ "gulp")
> Gulp.js 是一个自动化构建工具,开发者可以使用它在项目开发过程中自动执行常见任务。Gulp.js 是基于 Node.js 构建的,利用 Node.js 流的威力,你可以快速构建项目并减少频繁的 IO 操作。Gulp.js 源文件和你用来定义任务的 Gulp 文件都是通过 JavaScript(或者 CoffeeScript )源码来实现的。
使用教程:
使用前准备确认你的环境中有node 和npm
node -v
npm -v
1,下载安装
npm install --global gulp
npm install --save-dev gulp
意思就是全局安装,这样能避免我们运行gulp命令时提示command not found的错误,
确认下安装完成了
gulp -v
如果显示版本号,没有提示命令未找到,就可以继续往下了
2,安装相关插件
npm install gulp-connect
npm install run-sequence
npm install gulp-rev
npm install gulp-rev-collector
npm install gulp-util
注:我安装到了项目的同级目录,后面的操作请注意路径问题
等上述命令执行完之后,在项目同级目录下应该会生成node_modules文件夹,里面即是安装的gulp的插件
3,确认无误后,我们需要新建一个名字叫gulpfile.js的脚本
附上我的文件内容,仅供参考,注意路径问题!!!
//引入gulp和gulp插件
var gulp = require('gulp'),
runSequence = require('run-sequence'),
//minifycss = require('gulp-minify-css'),压缩css需要的插件,感兴趣的可以下载
//uglify = require('gulp-uglify'),压缩js需要的插件,感兴趣的可以下载
rev = require('gulp-rev'),
revCollector = require('gulp-rev-collector');
//定义css、js源文件路径。这里填写自己真实的路径
var cssSrc = 'yourproject/Public/css/*.css',
jsSrc = 'yourproject/Public/js/*.js';
//CSS生成文件hash编码并生成 rev-manifest.json文件名对照映射
gulp.task('revCss', function(){
return gulp.src(cssSrc)
.pipe(rev())
.pipe(rev.manifest())
//.pipe(minifycss()) //压缩css,需要新的插件,下载速度太慢,我放弃了
.pipe(gulp.dest('rev/css'));
});
//js生成文件hash编码并生成 rev-manifest.json文件名对照映射
gulp.task('revJs', function(){
return gulp.src(jsSrc)
.pipe(rev())
.pipe(rev.manifest())
//.pipe(uglify()) ////压缩JS,需要新的插件,下载速度太慢,我放弃了
.pipe(gulp.dest('rev/js'));
});
//Html替换css、js文件版本
gulp.task('revHtml', function () {
return gulp.src(['rev/**/*.json', 'yourproject/Application/**/View/**/*.html'])//填写自己的真实模板存放位置
.pipe(revCollector())
.pipe(gulp.dest('yourproject/Application'));
});
//task合并顺序执行
gulp.task('dev', function (done) {
condition = false;
runSequence(
['revCss'],
['revJs'],
['revHtml'],
done);
});
gulp.task('default', ['dev']);
这个文件我的理解就是建立一个任务,监视js,css,文件内容是否改变
4,接下来修改相关插件
打开node_modulesgulp-revindex.js第144行
manifest[originalFile] = revisionedFile;
更新为: manifest[originalFile] = originalFile + '?v=' + file.revHash;
打开nodemodulesgulp-rev
odemodules
ev-pathindex.js
10行 return filename + '-' + hash + ext;
更新为: return filename + ext;
打开node_modulesgulp-rev-collectorindex.js
31行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) ) {//每次覆盖版本信息
打开node_modulesgulp-rev-collectorindex.js
第107行 regexp: new RegExp( '([/\\'"])' + pattern, 'g' ),
更新为: regexp: new RegExp( '([/\\'"])' + pattern+'(\?v=\w{10})?', 'g' ),
大致意思就是更改gulp默认的规则,在js,css文件后面追加?v=xxxx
到这里如果没什么问题的话,全部步骤就已经完成了。其中需要注意的就是gulpfile.js中的路径问题.
5,运行命令
gulp dev
如果没什么问题的话,就能实现下边的效果
——————————-在dologin.js内容改变后—————————————
至此结束 2016-11-30 01:08:52 星期三
@saonian 咦,咋那么多人哩
@saoni北坡说咦咋那么多人呢an
我在北方的炕头上静静地看博主更新
谢谢喽
谢谢博主的辛苦整理
有阅读价值