我正试着和肝脏一起工作。Gulp并不控制web服务器本身(实际的web应用程序是一个php站点)。当我在服务器上运行nmap时,我发现livereload无法工作,而chrome扩展也表明了同样的情况。
我的任务是:
gulp = require 'gulp'
{livereload} = require('gulp-load-plugins')()
gulp.task 'watch', ['styles'], ->
livereload.listen()
gulp.watch './public/include/less/**/*.less', ['styles']
gulp.watch('./public/include/css/**/*.css').on('change', livereload.changed)发布于 2015-04-19 13:59:20
下面是一个基于 livereload solution服务器以及connect-livereload和gulp-livereload插件的connect-livereload:
var gulp = require('gulp');
var connect = require('connect');
var connectLivereload = require('connect-livereload');
var opn = require('opn');
var gulpLivereload = require('gulp-livereload');
var config = {
rootDir: __dirname,
servingPort: 8080,
// the files you want to watch for changes for live reload
filesToWatch: ['*.{html,css,js}', '!Gulpfile.js']
}
// The default task - called when you run `gulp` from CLI
gulp.task('default', ['watch', 'serve']);
gulp.task('watch', ['connect'], function () {
gulpLivereload.listen();
gulp.watch(config.filesToWatch, function(file) {
gulp.src(file.path)
.pipe(gulpLivereload());
});
});
gulp.task('serve', ['connect'], function () {
return opn('http://localhost:' + config.servingPort);
});
gulp.task('connect', function(){
return connect()
.use(connectLivereload())
.use(connect.static(config.rootDir))
.listen(config.servingPort);
});编辑。
我错过了PHP部分。我还没有用过它,但这可能对你有帮助:https://github.com/micahblu/gulp-connect-php
发布于 2016-01-08 22:57:44
为什么不使用浏览器同步?很简单也不那么复杂。
他是自动打开浏览器窗口与默认端口3000。
下面是简单的使用示例:
var gulp = require(''gulp),
browserSync = require('browser-sync').create();
// Static server
gulp.task('browser-sync', function() {
browserSync.init({
server: {
baseDir: "./flex_grid/"
}
});
});下面是sass编译的一个简单的使用示例:
var gulp = require('gulp'),
sass = require('gulp-ruby-sass'),
watch = require('gulp-watch'),
sourcemaps = require('gulp-sourcemaps'),
autoprefixer = require('gulp-autoprefixer');
var browserSync = require('browser-sync').create();
gulp.task('default', ['serve']);
gulp.task('serve', ['sass'], function() {
browserSync.init({
server: "./flex_grid/"
});
gulp.watch("src/sass/*.scss", ['sass']);
gulp.watch("flex_grid/*.html").on('change', browserSync.reload);
});
gulp.task('sass', function() {
return sass(
'src/sass/flex_grid.scss', {
style: 'expanded',
sourcemap: true
}).on('error', function (err) {
console.error('Error! ', err.message);
})
.pipe(autoprefixer({
browsers: [ '> 0%', 'last 2 versions', 'Firefox ESR', 'Opera 12.1' ],
cascade: false
}))
.on('error', function (err) {
console.error('Error! ', err.message);
})
.pipe(sourcemaps.write('.', {
includeContent: false
}))
.on('error', function (err) {
console.error('Error! ', err.message);
})
.pipe(gulp.dest('flex_grid'))
.pipe(browserSync.stream());
});https://stackoverflow.com/questions/27924121
复制相似问题