gpt4 book ai didi

javascript - 我可以将 gulp livereload 设置为在编译所有文件后运行吗?

转载 作者:搜寻专家 更新时间:2023-11-01 05:11:32 24 4
gpt4 key购买 nike

我已经设置了一个 gulp 来与 Stylus、Jade 和 tiny-lr 一起工作。我的问题是,当我保存一个 jade 文件时,它开始编译它们,因此在我当前正在处理的文件被编译之前,复制到目标的第一个文件会实时重新加载,导致我不得不手动刷新。我已经使用“gulp-changed”解决了这个问题,但我似乎无法配置它或其他东西。以前有人遇到过这个问题吗?我正在发布我的 Gulp 文件,以便您查看。

可以在此处找到问题的时间线图:https://www.dropbox.com/s/3g37oy25s9mq969/jade_compile_frefresh_problem.png?dl=0

感谢任何帮助!

    'use strict';

var gulp = require('gulp');
var jade = require('gulp-jade');
var gutil = require('gulp-util');
var stylus = require('gulp-stylus');
var jeet = require('jeet');
var nib = require('nib');
var uglify = require('gulp-uglify');
var lr = require('tiny-lr')();
// var mainBowerFiles = require('main-bower-files');

// Define sources object
var sources = {
jade: "jade/**/*.jade",
partials: "partials/**/*.jade",
stylus: "styl/**/*.styl",
scripts: "js/**/*.js"
};

// Define destinations object

var destinations = {
html: "dist/",
css: "dist/css",
js: "dist/js"
};

// Compile and copy Jade
gulp.task("jade", function(event) {
return gulp.src(sources.jade)
.pipe(jade({
pretty: true
})).pipe(gulp.dest(destinations.html));
});

// Compile and copy Stylus
gulp.task("stylus", function(event) {
return gulp.src(sources.stylus).pipe(stylus({
use: [nib(), jeet()],
import: [
'nib',
'jeet'
],
style: "compressed"
})).pipe(gulp.dest(destinations.css));
});

// Minify and copy all JavaScript
gulp.task('scripts', function() {
gulp.src(sources.scripts)
.pipe(uglify())
.pipe(gulp.dest(destinations.js));
});

// Consolidate Bower Files and copy to /dist/js/
// gulp.task('bower-files', function() {
// return gulp.src(mainBowerFiles(/* options */), {})
// .pipe(gulp.dest(destinations.js));
// });

// Watch for file changes and execute tasks
gulp.task("watch", function() {
gulp.watch(sources.jade, ["jade"]);
gulp.watch(sources.partials, ["jade"]);
gulp.watch(sources.stylus, ["stylus"]);
gulp.watch(sources.scripts, ["scripts"]);
gulp.watch('dist/**/*', refresh);
});

// Live Reload
gulp.task('serve', function () {
var express = require('express');
var app = express();
app.use(require('connect-livereload')());
app.use(express.static(__dirname+'/dist/'));
app.listen(4000, '0.0.0.0');
lr.listen(35729);
});

// Define default task
gulp.task("default", ["jade", "stylus", "scripts", "serve", "watch"]);

// Refresh function
var refresh = function(event) {
var fileName = require('path').relative(__dirname, event.path);
gutil.log.apply(gutil, [gutil.colors.magenta(fileName), gutil.colors.cyan('built')]);
lr.changed({
body: { files: [fileName] }
});
};

最佳答案

我通过在我的 gulpfile.js 中编写一个简单的 javascript 函数实现了这一点

我这样做是因为当我编译我的 sass 文件时,livereload 将运行大约 10 次,这种方法将使其只运行一次。

我的 gulpfile.js

gulp.task('watch', function() {
$.livereload.listen();

gulp.watch([
path.join(config.path.app, 'media/js/**/*.js'),
path.join(config.path.app, 'media/css/**/*.css'),
path.join(config.path.app, 'templates/**/*.html')
]).on('change', stackReload);

// a timeout variable
var timer = null;

// actual reload function
function stackReload() {
var reload_args = arguments;

// Stop timeout function to run livereload if this function is ran within the last 250ms
if (timer) clearTimeout(timer);

// Check if any gulp task is still running
if (!gulp.isRunning) {
timer = setTimeout(function() {
$.livereload.changed.apply(null, reload_args);
}, 250);
}
}

});

关于javascript - 我可以将 gulp livereload 设置为在编译所有文件后运行吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25384796/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com