browser-sync не обновляет страницу после изменений с помощью Gulp
Я новичок в Gulp, и я хотел использовать его автоматическую компиляцию scss и синхронизацию браузера. Но я не могу заставить его работать.
Я раздел все, чтобы оставить только содержимое примера на веб-сайте Browsersync:
http://www.browsersync.io/docs/gulp/#gulp-sass-css
var gulp = require('gulp');
var browserSync = require('browser-sync').create();
var sass = require('gulp-sass');
// Static Server + watching scss/html files
gulp.task('serve', ['sass'], function() {
browserSync.init({
server: "./app"
});
gulp.watch("app/scss/*.scss", ['sass']);
gulp.watch("app/*.html").on('change', browserSync.reload);
});
// Compile sass into CSS & auto-inject into browsers
gulp.task('sass', function() {
return gulp.src("app/scss/*.scss")
.pipe(sass())
.pipe(gulp.dest("app/css"))
.pipe(browserSync.stream());
});
gulp.task('default', ['serve']);
Я могу назвать gulp служить. Сайт показывает, и я получаю сообщение от Browsersync. Когда я изменяю HTML, страница перезагружается. Когда, Однако, я измените scss, я вижу это:
[BS] 1 file changed (test.css)
[15:59:13] Finished 'sass' after 18 ms
но я должен перезагрузить вручную. Что я упускаю?
8 ответов
вы можете просто ввести изменения вместо того, чтобы заставлять полное обновление браузера при компиляции SASS, если хотите.
browserSync.init({
injectChanges: true,
server: "./app"
});
gulp.task('sass', function() {
return gulp.src("app/scss/*.scss")
.pipe(sass())
.pipe(gulp.dest("app/css"))
.pipe(browserSync.stream({match: '**/*.css'}));
});
Я также столкнулся с аналогичной проблемой, когда я был новичком в использовании синхронизации браузера, в командной строке говорилось "перезагрузка браузеров", но браузер не был обновлен вообще, проблема заключалась в том, что я не включил тег тела в свою HTML-страницу, где браузер-синхронизация может вводить скрипт для его функциональности, убедитесь, что Ваша HTML-страница имеет тег тела.
Это потому, что ты называешь browserSync.reload
на часах html, а не на часах scss.
попробуйте это:
gulp.watch("app/scss/*.scss", ['sass']).on('change', browserSync.reload);
gulp.watch("app/*.html").on('change', browserSync.reload);
Это то, что я использую, и он отлично работает в sass или любых других файлах
gulp.task('browser-sync', function () {
var files = [
'*.html',
'css/**/*.css',
'js/**/*.js',
'sass/**/*.scss'
];
browserSync.init(files, {
server: {
baseDir: './'
}
});
});
столкнулся с этой же проблемой при попытке перезагрузить php
и js
файлы и поток css
файлы. Я смог использовать stream только с помощью pipe
метод, который имеет смысл. Во всяком случае, вот что сработало для меня:
gulp.watch(['./**/*.css']).on('change', function (e) {
return gulp.src( e.path )
.pipe( browserSync.stream() );
});
но я на самом деле предпочитаю, чтобы ответ @ pixie был изменен:
gulp.task('default', function() {
var files = [
'./**/*'
];
browserSync.init({
files : files,
proxy : 'localhost',
watchOptions : {
ignored : 'node_modules/*',
ignoreInitial : true
}
});
});
У меня также была та же проблема. Это сработало, когда я вызвал метод reload как отдельную задачу.
gulp.task('browserSync', function() {
browserSync.init(null, {
server: {
baseDir: './'
},
});
})
gulp.task('reload', function(){
browserSync.reload()
})
gulp.task('watch', ['sass', 'css', 'browserSync'], function(){
gulp.watch('*.html', ['reload']);
})
иногда при использовании CLI у вас нет сценария, вставленного в ваши основные файлы HTML, поэтому вы должны вручную добавить это или использовать gulp.
<!-- START: BrowserSync Reloading -->
<script type='text/javascript' id="__bs_script__">
//<![CDATA[
document.write("<script async src='/browser-sync/browser-sync-client.js'><\/script>".replace("HOST", location.hostname));
//]]>
</script>
<!-- END: BrowserSync Reloading -->
Я включаю это в свой html, прямо под тегом body. Это работает.
<script type='text/javascript' id="__bs_script__">//<![CDATA[
document.write("<script async src='http://HOST:3000/browser-sync/browser-sync-client.2.11.1.js'><\/script>".replace("HOST", location.hostname));//]]>
</script>