我使用BrowserSync为我的项目编写了一个监视任务,我遇到了一个我似乎无法弄清楚的障碍。任务不是太疯狂,观察文件然后重新加载浏览器并根据需要编译sass或js(browserify)。
问题在于,当我保存一个js文件(比如app.js
)时,它会刷新浏览器,然后编译js&创建bundle.js
文件,然后还会触发浏览器刷新。所以我总是得到至少2次更新。有时它甚至可以达到10-15次的清爽循环。
对我来说最好的是能够禁用自动刷新并自己触发它,这样我就可以保持逻辑编译,然后在完成后我可以触发浏览器刷新。
BrowserSync有一种触发刷新的方法,但是如何阻止默认刷新?
下面列出了Js,请注意我不想再包括watchify或其他任何模块。
// Dependancies
// ---------------------------
var browserSync = require("browser-sync");
var sass = require('node-sass');
var fs = require('fs');
var sys = require('sys');
var exec = require('child_process').exec;
var chalk = require('chalk');
// Used to create & listen for events
var emit = browserSync.emitter;
// Start BrowserSync
browserSync({
files: [
'views/**',
'assets/js/**',
'assets/sass/**'
],
proxy: "localhost:8080",
ghostMode: false,
open: false,
port: 9090,
watchOptions: {
reloadDelay: 1000,
debounceDelay: 1000
}
});
// When a file is changed
emit.on("file:changed", function (res) {
// On file save, the `file:changed` event is fired twice.
// Only listen for the `core` response.
if(res.namespace !== 'core') return false;
// File extention
var ext = res.path.split('.').pop();
// Emit the compile events when appropriate
switch(ext){
case 'scss':
emit.emit('compile-sass');
break;
case 'js':
emit.emit('compile-js');
break;
}
});
// Compile Sass Event
emit.on("compile-sass", function(){
sass.render({
file: 'assets/sass/styles.scss',
outFile: 'assets/css/styles.css',
sourceMap: true,
sourceMapEmbed: true,
outputStyle: 'compressed',
success: function(result) {
console.log("[" + chalk.blue('SS') + "] " + chalk.cyan("Watch:") + " Sass -> Css Compiling Successful");
// Write the results to the css file
fs.writeFile("assets/css/styles.css", result.css, function(err) {
if(!err) return console.log("[" + chalk.blue('SS') + "] " + chalk.cyan("Watch:") + chalk.magenta(' styles.css') + " saved successfully");
console.log("[" + chalk.blue('SS') + "] " + chalk.cyan("Watch:") + "There was an error writing to styles.css", err);
});
}
});
});
// Compile Js Event
emit.on("compile-js", function(){
exec("browserify assets/js/app.js -o assets/js/bundle.js --debug", function (err, stdout, stderr) {
if(err) throw err;
console.log("[" + chalk.blue('SS') + "] " + chalk.cyan('Watch:') + chalk.magenta(' bundle.js') + ' successfully created');
});
});
答案 0 :(得分:1)
BrowserSync没有理由看你的源文件。根据您的描述,BrowserSync应该关注的唯一事件是在编写bundle.js
时,其他一些工具正在查看源文件以进行编译。
您的JS手表可以简化为bundle.js
,您也可以放弃reloadDelay
和debounceDelay
。