jekyll/sass/js를보고 브라우저와 동기화 할 gulpfile을 만들려고합니다. 스크립트는 jekyll의 변경 사항을 정확하게 감시하고 브라우저에서 모든 변경 사항을 다시 작성하고 삽입합니다.gulp watch and reload jekyll, sass, js
그러나 나는 그들이 혐오스럽게 변한 이유가 무엇인지 알 수 없다. 어떤 도움을 주시면 감사하겠습니다!
https://github.com/Skoks/JekyllBB
/* GULPFILE.JS */
var gulp = require('gulp'),
sass = require('gulp-sass'),
browserSync = require('browser-sync'),
autoprefixer = require('gulp-autoprefixer'),
uglify = require('gulp-uglify'),
jshint = require('gulp-jshint'),
header = require('gulp-header'),
rename = require('gulp-rename'),
minifyCSS = require('gulp-minify-css'),
cp = require('child_process');
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']);
});
지킬은 사이트를'_site' 폴더에 생성합니다. SASS의 결과를 _site에 복사하는 스크립트에는 표시되지 않습니다. –
이 폴더를/html로 변경했습니다. 또한 https://github.com/Skoks/JekyllBB에 대한 git repo를 참조했습니다. 감사! – iamskok
나는 꿀꺽 꿀꺽 마시지 않았다. 나는 꿀꺽 꿀꺽 비슷한 설정을 해. 당신에게 도움이된다면 쓸데없는 파일을보십시오. https://github.com/madhur/madhur.github.com/blob/source/Gruntfile.js –