Ответ 1
Отключение исходных карт - это какая-то тайна прямо сейчас. Вы должны сделать это так:
.pipe(sass({ "sourcemap=none": true }))
Получение странной ошибки с помощью основного gulp/экспресс-сборки.
Макет каталога
project/
- sass/
- style.scss
- gulpfile.js
- index.html
Gulpfile.js
var gulp = require('gulp'),
sass = require('gulp-ruby-sass'),
autoprefixer = require('gulp-autoprefixer'),
minifycss = require('gulp-minify-css'),
rename = require('gulp-rename');
gulp.task('express', function() {
var express = require('express');
var app = express();
app.use(require('connect-livereload')({port: 4002}));
app.use(express.static(__dirname));
app.listen(4000);
});
var tinylr;
gulp.task('livereload', function() {
tinylr = require('tiny-lr')();
tinylr.listen(4002);
});
function notifyLiveReload(event) {
var fileName = require('path').relative(__dirname, event.path);
tinylr.changed({
body: {
files: [fileName]
}
});
}
gulp.task('styles', function() {
return gulp.src('sass/*.scss')
.pipe(sass({ style: 'expanded', sourcemap: false }))
.pipe(autoprefixer('last 2 version', 'safari 5', 'ie 8', 'ie 9', 'opera 12.1'))
.pipe(gulp.dest('css'))
.pipe(rename({suffix: '.min'}))
.pipe(minifycss())
.pipe(gulp.dest('css'));
});
gulp.task('watch', function() {
gulp.watch('sass/*.scss', ['styles']);
gulp.watch('*.html', notifyLiveReload);
gulp.watch('css/*.css', notifyLiveReload);
});
gulp.task('default', ['styles', 'express', 'livereload', 'watch'], function() {
});
Style.scss
body { position: relative; }
Экспресс-сервер/печенье работает отлично, но когда он пытается скомпилировать таблицу стилей, я получаю эту ошибку (даже с sourcemap: false
)
gulp-ruby-sass: write style.css.map
events.js:72
throw er; // Unhandled 'error' event
^
Error: <LOCAL_PATH_HERE>/style.css.map:3:1: Unknown word
Отключение исходных карт - это какая-то тайна прямо сейчас. Вы должны сделать это так:
.pipe(sass({ "sourcemap=none": true }))
Не совсем уверен, почему это исправляет его, но сменив канал autoprefixer на:
.pipe(autoprefixer({
browsers: ['last 2 versions'],
cascade: false
}))
и помещая его перед тем, как труба sass (верхняя) позволяет ей успешно строить.
Я исправил эту проблему, сохраняя исходные карты и используя gulp-filter:
var filter = require('gulp-filter')
var filterCSS = filter('**/*.css');
gulp.task('styles', function() {
return gulp.src('sass/*.scss')
.pipe(sass({ style: 'expanded', sourcemap: true }))
// Filters only css files before auto prefixing
.pipe(filterCSS)
.pipe(autoprefixer('last 2 version', 'safari 5', 'ie 8', 'ie 9', 'opera 12.1'))
.pipe(filterCSS.restore())
.pipe(gulp.dest('css'))
.pipe(rename({suffix: '.min'}))
.pipe(minifycss())
.pipe(gulp.dest('css'));
});
У меня была такая же проблема с плагином gulp -ruby-sass. Я нашел этот блог, в котором объясняется, что есть пара ошибок в плагине gulp -ruby-sass относительно исходных карт. Они оба были закрыты чуть более недели назад. Если вы переходите на gulp -ruby-sass ~ 1.0.0-alpha, это должно устранить проблемы, связанные с исходными картами.
Если это не работает, статья, связанная с выше, показывает, как использовать плагин gulp -sass, который не имеет проблемы с исходной картой.
Попробуйте перейти на gulp -ruby-sass 1.0.0-alpha. Он использует gulp -sourcemaps и должен избегать всех итераций этой проблемы.