Zobacz poniżej. Problem z moim obecnym kodem polega na tym, że Sourcemaps nie są wstrzykiwane za pomocą Browsersync. Czy tu coś pomijam lub robię to w niewłaściwy sposób?Gulp: Jak korzystać z Browsersync, Sourcemaps, Autoprefixer i CSS Cleaner?
Dla porównania: https://www.browsersync.io/docs/gulp/#gulp-sass-maps
// requirements
var gulp = require('gulp');
var sass = require('gulp-ruby-sass');
var browserSync = require('browser-sync').create();
var prefix = require('gulp-autoprefixer');
var rename = require('gulp-rename');
var sourcemaps = require('gulp-sourcemaps');
var cssclean = require('gulp-clean-css');
// create sass tasks
gulp.task('sass', function() {
return sass('assets/scss/style.scss', {sourcemap: true, style: 'compact'})
.on('error', function (err) {
console.error('Error!', err.message);
})
.pipe(rename({suffix: '.min'}))
.pipe(cssclean())
.pipe(prefix("last 2 versions", "> 1%", "ie 8", "Android 2", "Firefox ESR"))
.pipe(sourcemaps.write('.'))
.pipe(gulp.dest('assets/styles'))
.pipe(browserSync.stream({match: '**/*.css'}))
});
gulp.task('serve', ['sass'], function() {
browserSync.init({
proxy: "localhost/portfolio2014",
open:false
});
gulp.watch("assets/scss/**/*.scss", ['sass']);
gulp.watch(["assets/styles/*.css", "site/**/*", "content/**/*", "assets/javascript/*.js"]).on('change', browserSync.reload);
});
// default task (just run gulp)
gulp.task('default', ['serve']);
Dzięki za pomoc. Co dziwne, moja własna odpowiedź wydaje się działać teraz, ale nie ta. Będę musiał przyjrzeć się temu nieco dalej i zobaczyć, co mogę wymyślić. Na pewno ci pomogłeś, dzięki! – gburning
Cieszę się, że mogę pomóc. Powyższy kod jest swego rodzaju hybrydą i testowałem - musiałem uruchomić [serwer] (https://www.browsersync.io/docs/options/#option-server) dla przeglądarkiSync i zmienić niektóre nazwy plików, co może być przyczyną, dla której nie zadziałało od razu. – Barryman9000