【发布时间】:2015-10-02 17:59:56
【问题描述】:
我正在尝试让 browserSync 与 typescript 编译器和 angular 一起使用。当我在 app.ts 中更改某些内容时,它会正确重新编译,并且 browsersync 会打印“正在重新加载浏览器...”,但浏览器从未真正重新加载。我似乎无法弄清楚为什么它没有重新加载,也许它与 Angular 2 处理刷新的方式有关?
var gulp = require('gulp');
var sourcemaps = require('gulp-sourcemaps');
var tsc = require('gulp-typescript');
var tsProject = tsc.createProject('tsconfig.json');
var config = require('./gulp.config')();
var browserSync = require('browser-sync').create();
var reload = browserSync.reload;
// Start a local server in base directory
gulp.task('serve', function() {
browserSync.init({
server: {
baseDir: './'
}
});
// Watch for changes in html and ts files in base directory, reload if they occur
gulp.watch(['*.html', '*.ts'], ['reloady']);
// Watches for changes in css files, grabs the files, pipes them to browsersync stream
// This injects the css into the page without a reload
gulp.watch('*.css', function() {
gulp.src('*css')
.pipe(browserSync.stream());
});
});
gulp.task('compile-ts', function() {
var sourceTsFiles = [
config.allTs,
config.typings
];
var tsResult = gulp
.src(sourceTsFiles)
.pipe(sourcemaps.init())
.pipe(tsc(tsProject));
return tsResult.js
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest(config.tsOutputPath))
});
gulp.task('reloady', ['compile-ts'], function() {
console.log("Reload SHOULD have happened.");
browserSync.reload();
});
编辑:已解决!为了让 Browsersync 正确连接,body 标签必须存在于您的网站中(我们在它之后添加一个脚本标签)。有关详细信息,请参阅下面的答案。
【问题讨论】:
-
我想停用 BrowserSync,在我的项目中找不到此代码。你能写完整的路径吗?我使用角度 2
标签: angular typescript gulp browser-sync