Our project is using Gulp. Now I have a requirement: we have multiple page-level HTML files, say login.html
and my.html
. Inside these original HTML files there is a variable called {{PAGE_TITLE}}
, which should be replaced (by Gulp
) to be "Login to System"
and "My Account"
respectively. Here is my current script:
gulp.task('pages', ['clean:tmp'], function () {
var pageTitle = '';
return gulp.src('/my/source/html/**/*.html')
.pipe(tap(function (file, t) {
pageTitle = /index.html$/.test(file.path) ? 'Login to System' : 'My Account';
}))
.pipe(replace(/{{PAGE_TITLE}}/g, pageTitle))
.pipe(gulp.dest('/my/dest/'));
});
It turns out the variable pageTitle
is never set before the replace
. I have searched for documentation of gulp-tap
for tons of times, but I still do not know how to make it work. Please help, thanks.
This post: Modify file in place (same dest) using Gulp.js and a globbing pattern tries to achieve the same affect, but he resulted in some other solution.
I figured out the solution as followed: