1
1

Товарищи, доброго времени суток.

Появилась проблема после донастройки Gulp'а в уроке 3.27 - перестали работать скрипты (как на сервере так и через запуск самого html файла(пути прописаны корректно)).

Сначала подумал, что переписал gulp неправильно, но скопировав код из репозитория Ивана проблема не исчезла...

Начал рыться в Gulpfile.js и в папке dist, не совсем понимаю логику:

Код из репозитория:

const gulp        = require('gulp');
const browserSync = require('browser-sync');
const sass        = require('gulp-sass');
const cleanCSS = require('gulp-clean-css');
const autoprefixer = require('gulp-autoprefixer');
const rename = require("gulp-rename");
const imagemin = require('gulp-imagemin');
const htmlmin = require('gulp-htmlmin');

gulp.task('server', function() {

    browserSync({
        server: {
            baseDir: "dist"
        }
    });

    gulp.watch("src/*.html").on('change', browserSync.reload);
});

gulp.task('styles', function() {
    return gulp.src("src/sass/**/*.+(scss|sass)")
        .pipe(sass({outputStyle: 'compressed'}).on('error', sass.logError))
        .pipe(rename({suffix: '.min', prefix: ''}))
        .pipe(autoprefixer())
        .pipe(cleanCSS({compatibility: 'ie8'}))
        .pipe(gulp.dest("dist/css"))
        .pipe(browserSync.stream());
});

gulp.task('watch', function() {
    gulp.watch("src/sass/**/*.+(scss|sass|css)", gulp.parallel('styles'));
    gulp.watch("src/*.html").on('change', gulp.parallel('html'));
});

gulp.task('html', function () {
    return gulp.src("src/*.html")
        .pipe(htmlmin({ collapseWhitespace: true }))
        .pipe(gulp.dest("dist/"));
});

gulp.task('scripts', function () {
    return gulp.src("src/js/**/*.js")
        .pipe(gulp.dest("dist/js"));
});

gulp.task('fonts', function () {
    return gulp.src("src/fonts/**/*")
        .pipe(gulp.dest("dist/fonts"));
});

gulp.task('icons', function () {
    return gulp.src("src/icons/**/*")
        .pipe(gulp.dest("dist/icons"));
});

gulp.task('mailer', function () {
    return gulp.src("src/mailer/**/*")
        .pipe(gulp.dest("dist/mailer"));
});

gulp.task('images', function () {
    return gulp.src("src/img/**/*")
        .pipe(imagemin())
        .pipe(gulp.dest("dist/img"));
});

gulp.task('default', gulp.parallel('watch', 'server', 'styles', 'scripts', 'fonts', 'icons', 'mailer', 'html', 'images'));

1) tasks 'server' и 'html': зачемем gulp'у следить за черновым html и перезапускаться при наличии изменений в черновом html, если ресурсом к отображению в браузере является чистовой html? Понимаю, что изменения в чистовом html происходят параллельно с изменениями в черновом, но не будет ли правильнее перезапускать gulp только после изменений в чистовом html во избежание каких либо конфузов? Или я не правильно понимаю значение 'change'? change Означает просто изменение или сохранение после внесения изменений?

2) task 'scripts' - суть своей изначальной проблемы я вроде как понял, gulp не вносит изменения в чистовых файлах после сохранения изменений в черновых. Вроде как даже вносит только после перезапуска самого gulp'а через терминал, но такой расклад вряд ли кому-то подойдет. подумывал как вариант добавить в задачу "watch":

gulp.watch("src/js/*.js").on('change', gulp.parallel('scripts'));

но че то не получается:(

И даже после внесения кода скрипта, например

$(document).ready(function(){
  $('.your-class').slick();
});

в чистовой файл - никаких изменений нет.

Курс JavaScript'а еще не успел пройти, а настроить надо, помогите плз))

3 ) Строка

gulp.task('default', gulp.parallel('watch', 'server', 'styles', 'scripts', 'fonts', 'icons', 'mailer', 'html', 'images'));

а) что за задача 'default'? где она я ее нигде не нашел:(

б) зачем здесь 'style' и 'html' если они и так уже запускаются в задаче 'watch'?


Арсен М
4 years ago






Добрый день.

1) Здесь суть в порядке выполнения действий. Мы работаем в папке src с исходниками, в dist "руками" не лезем.

Мы вносим изменения в html файл внутри src => gulp отслеживает изменения, запускает нужный таск => минифицирует файл, помещает его в dist => параллельно он запускает второй таск, внутри "server" => это приводит к перезагрузке сервера, который берет html файл из dist (уже измененный)

Да, можно написать скрипт так, что будет отслеживаться файл из dist, но работать в этой папке - очень плохая практика.

2) Да, здесь сборшик настроен в основном на верстку. Для скриптов нужно добавить 2 строчки в 2х тасках:

gulp.task('scripts', function () {
    return gulp.src("src/js/**/*.js")
        .pipe(gulp.dest("dist/js"))
        .on("end", browserSync.reload);
});

и

gulp.task('watch', function() {
    gulp.watch("src/sass/**/*.+(scss|sass|css)", gulp.parallel('styles'));
    gulp.watch("src/*.html").on('change', gulp.parallel('html'));
    gulp.watch("./src/js/**/*.js", gulp.parallel("scripts"));
});

Теперь все изменения в js файлах будут отслеживаться и страница будет при этом автоперезагружаться.

3) a) Это задача по умолчанию, когда мы просто прописываем в строку gulp

b) Эти задачи включены сюда для первичной инициализации. Бывает так, что вносятся изменения без запуска gulp. Потом его запускают, а на странице изменений нет! Почему? Потому что watch еще не знает, что было изменено, он запустится только после внесенных изменений с запущенным gulp.

И чтобы не терять и сразу показать измения - они находятся здесь.

Иван Петриченко
4 years ago

Один ответ