gpt4 book ai didi

javascript - gulp watch 并重新加载 jekyll、sass、js

转载 作者:塔克拉玛干 更新时间:2023-11-02 20:34:19 24 4
gpt4 key购买 nike

我正在尝试构建一个 gulpfile,它将监视 jekyll/sass/js 并与浏览器同步。该脚本正确地监视了 jekyll 的变化,重建并注入(inject)了浏览器中的所有变化。

但我不明白为什么它不同步 sass/js 更改,即使它们已被监视和重新生成。任何帮助将不胜感激!

/*** gulp.js ***/

var gulp = require('gulp');
var sass = require('gulp-sass');
var browserSync = require('browser-sync');
var autoprefixer = require('gulp-autoprefixer');
var uglify = require('gulp-uglify');
var jshint = require('gulp-jshint');
var header = require('gulp-header');
var rename = require('gulp-rename');
var minifyCSS = require('gulp-minify-css');
var cp = require('child_process');
var package = require('./package.json');

var messages = {
jekyllBuild: '<span style="color: grey">Running:</span> $ jekyll build'
};

var banner = [
'/*!\n' +
' * <%= package.name %>\n' +
' * <%= package.title %>\n' +
' * <%= package.url %>\n' +
' * @author <%= package.author %>\n' +
' * @version <%= package.version %>\n' +
' * Copyright ' + new Date().getFullYear() + '. <%= package.license %> licensed.\n' +
' */',
'\n'
].join('');


/**
* Build the Jekyll Site
*/
gulp.task('jekyll-build', function (done) {
browserSync.notify(messages.jekyllBuild);
return cp.spawn('jekyll', ['build'], {stdio: 'inherit'})
.on('close', done);
});

/**
* Rebuild Jekyll & do page reload
*/
gulp.task('jekyll-rebuild', ['jekyll-build'], function () {
browserSync.reload();
});

/**
* Wait for jekyll-build, then launch the Server
*/
gulp.task('browser-sync', ['css', 'js', 'jekyll-build'], function() {
browserSync({
server: {
baseDir: 'html'
}
});
});

gulp.task('css', ['bs-reload'], function () {
return gulp.src('themes/dental-theme/assets/scss/main.scss')
.pipe(sass({errLogToConsole: true}))
.pipe(autoprefixer(['last 15 versions', '> 1%', 'ie 8', 'ie 7'], { cascade: true }))
.pipe(gulp.dest('build/css'))
.pipe(minifyCSS())
.pipe(rename({ suffix: '.min' }))
.pipe(header(banner, { package : package }))
.pipe(gulp.dest('build/css'))
.pipe(browserSync.reload({stream:true}));
});

gulp.task('js',function(){
gulp.src('themes/dental-theme/assets/js/main.js')
.pipe(jshint('.jshintrc'))
.pipe(jshint.reporter('default'))
.pipe(header(banner, { package : package }))
.pipe(gulp.dest('build/js'))
.pipe(uglify())
.pipe(header(banner, { package : package }))
.pipe(rename({ suffix: '.min' }))
.pipe(gulp.dest('build/js'))
.pipe(browserSync.reload({stream:true, once: true}));
});

gulp.task('browser-sync', function() {
browserSync.init(null, {
server: {
baseDir: "html"
}
});
});
gulp.task('bs-reload', function () {
browserSync.reload();
});

gulp.task('default', ['css', 'js', 'browser-sync'], function () {
gulp.watch("themes/dental-theme/assets/scss/*.scss", ['css']);
gulp.watch("themes/dental-theme/assets/js/*.js", ['js']);
gulp.watch(['index.html', '_layouts/*.html', '_posts/*'], ['jekyll-rebuild']);
});

最佳答案

您的 js 和 css watch 只是重新生成文件,而不是进行 Jekyll 构建,而您的 html watch 会。

尝试:

gulp.task('default', ['css', 'js', 'browser-sync'], function () {
gulp.watch("assets/scss/*/*.scss", ['css', 'jekyll-rebuild']);
gulp.watch("assets/js/*.js", ['js', 'jekyll-rebuild']);
gulp.watch(['index.html', '_layouts/*.html', '_posts/*'], ['jekyll-rebuild']);
});

编辑:

如果你不想每次都构建你的 Jekyll,你可以将生成的 Assets 复制到目标文件夹:

gulp.task('default', ['css', 'js', 'browser-sync'], function () {
gulp.watch("assets/scss/*/*.scss", ['css', 'css-to-site']);
gulp.watch("assets/js/*.js", ['js', 'js-to-site']);
gulp.watch(['index.html', '_layouts/*.html', '_posts/*'], ['jekyll-rebuild']);
});

gulp.task('js-to-site', function () {
gulp.src('build/js/*')
.pipe(gulp.dest('html/themes/dental-theme/js'));
browserSync.reload();
});

gulp.task('css-to-site', function () {
gulp.src('build/css/*')
.pipe(gulp.dest('html/themes/dental-theme/css'));
browserSync.reload();
});

未测试。

关于javascript - gulp watch 并重新加载 jekyll、sass、js,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25737714/

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