BrowserSync正确刷新我正在修改的任何PHP页面,或SCSS或JS。但对于HTML文件,它不会刷新任何内容。为什么不呢?
注意我的gulpfile.js
嵌套在自己的子文件夹/gulp/
中,这是其内容:
var gulp = require('gulp');
var sass = require('gulp-sass');
var browserSync = require('browser-sync').create();
var autoprefixer = require('gulp-autoprefixer');
var plumber = require('gulp-plumber');
var onError = function (err) {
console.log('An error occurred:', gutil.colors.magenta(err.message));
gutil.beep();
this.emit('end');
};
gulp.task('sass', function() {
return gulp.src('../assets/styles/**/*.scss')
.pipe(plumber({ errorHandler: onError }))
.pipe(sass())
.pipe(autoprefixer())
.pipe(gulp.dest('../dist/styles'))
.pipe(browserSync.reload({stream: true}))
});
gulp.task('js', function() {
return gulp.src(['../assets/scripts/*.js'])
.pipe(gulp.dest('../dist/scripts'))
.pipe(browserSync.reload({
stream: true
}))
});
gulp.task('browserSync', function() {
browserSync.init({
proxy: 'http://127.0.0.1/vuejs/',
})
})
gulp.task('watch', ['browserSync','js','sass'], function() {
gulp.watch('../assets/styles/**/*.scss',['sass']);
gulp.watch('../**/**/*.php', browserSync.reload);
gulp.watch('../**/**/*.html', browserSync.reload);
gulp.watch('../assets/scripts/*.js', ['js']);
});
答案 0 :(得分:4)
你的观看'任务过于复杂,也许gulp变得混乱。尝试:
gulp.task('watch', ['browserSync','js','sass'], function() {
// you are already calling reload in your sass and js tasks so remove it here
// plus the array is for tasks, not a function call
// also those 'tasks' would run in parallel - which is not what you want
gulp.watch('../assets/styles/**/*.scss',['sass']);
gulp.watch('../**/**/*.php', browserSync.reload);
// you must be able to simplify the following three lines
// ** will match on zero or more entries so all three of these
// will match '../*.html', so try keeping only the first
// EDIT : try this for html reload
gulp.watch("../**/**/*.html").on("change", browserSync.reload);
// gulp.watch('../**/**/*.html', browserSync.reload);
// gulp.watch('../**/*.html', browserSync.reload);
// gulp.watch('../*.html', browserSync.reload);
// see above
gulp.watch('../assets/scripts/*.js', ['js']);
// a duplicate, remove
// gulp.watch('../*.html', browserSync.reload);
});
答案 1 :(得分:1)
我相信你的问题在于你使用的相对路径。为什么不设置gulp来观看这样的每个html文件:
// add reference to reload function in your var list
var reload = browserSync.reload;
gulp.task('watch', ['browserSync','js','sass'], function() {
gulp.watch("*.html").on("change", reload);
});
答案 2 :(得分:0)
我有一个类似的问题,转而注入HTML而不是完全重新加载 - 更快,你仍然得到你想要的更改。我使用了bs-html-injector。这就是你的样子。
var htmlInjector = require("bs-html-injector");
gulp.task('watch', ['browserSync','js','sass'], function() {
gulp.watch('../assets/styles/**/*.scss',['sass']);
gulp.watch('../**/**/*.php', browserSync.reload);
gulp.watch('../**/**/*.html', htmlInjector);
gulp.watch('../assets/scripts/*.js', ['js']);
});
请注意,您需要稍微更改一下browserync任务:
gulp.task('browsersync', function() {
browsersync.use(htmlInjector, {
files: "./wherever"
});
browsersync.init({
server:"./anotherfolder" //launch server
});
});
答案 3 :(得分:0)
gulp.task('watch', ['browserSync'], function() {
gulp.watch('../**/**/*.html', browserSync.reload);
gulp.watch('../assets/styles/**/*.scss',['sass']);
gulp.watch('../**/**/*.php', browserSync.reload);
gulp.watch('../assets/scripts/*.js', ['js']);
});
在这里我向链上提出了html动作,以防万一其中一个正在积极地搞乱它,也试着反过来。还删除了参数中的冗余。跑步" sass"和" js"我不需要或保证参数数组的内部,因为这些任务在每个gulp.watch行上运行,寻找基本代码的变化。