Answer the question
In order to leave comments, you need to log in
How to fix gulp3 code syntax under gulp 4?
Please help me to rewrite the file gulpfile.js
In the console I enter the gulp command.
Gives the following error:
assert.js:350
throw err;
^
AssertionError [ERR_ASSERTION]: Task function must be specified
at Gulp.set [as _setTask] (C:\Users\User\Desktop\G-p\node_modules\undertaker\lib\set-task.js:10:3)
at Gulp.task (C:\Users\User\Desktop\G-p\node_modules\undertaker\lib\task.js:13:8)
at Object.<anonymous> (C:\Users\User\Desktop\G-p\gulpfile.js:119:6)
at Module._compile (internal/modules/cjs/loader.js:701:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:712:10)
at Module.load (internal/modules/cjs/loader.js:600:32)
at tryModuleLoad (internal/modules/cjs/loader.js:539:12)
at Function.Module._load (internal/modules/cjs/loader.js:531:3)
at Module.require (internal/modules/cjs/loader.js:637:17)
at require (internal/modules/cjs/helpers.js:22:18)
'use strict';
var gulp = require('gulp'),
mainBowerFiles = require('main-bower-files'),
watch = require('gulp-watch'),
prefixer = require('gulp-autoprefixer'),
uglify = require('gulp-uglify'),
sourcemaps = require('gulp-sourcemaps'),
sass = require('gulp-sass'),
cleanCSS = require('gulp-clean-css'),
imagemin = require('gulp-imagemin'),
pngquant = require('imagemin-pngquant'),
rimraf = require('rimraf'),
browserSync = require("browser-sync"),
reload = browserSync.reload;
var path = {
vendor: {
js: 'app/js/',
css: 'app/css/'
},
dist: { //Тут мы укажем куда складывать готовые после сборки файлы
html: 'dist/',
js: 'dist/js/',
scss: 'dist/css/',
css: 'dist/css/',
img: 'dist/img/',
fonts: 'dist/fonts/'
},
app: { //Пути откуда брать исходники
html: 'app/*.html', //Синтаксис src/*.html говорит gulp что мы хотим взять все файлы с расширением .html
js: 'app/js/*.js',//В стилях и скриптах нам понадобятся только main файлы
scss: 'app/css/*.scss',
css: 'app/css/*.css',
img: 'app/img/**/*.*', //Синтаксис img/**/*.* означает - взять все файлы всех расширений из папки и из вложенных каталогов
fonts: 'app/fonts/**/*.*'
},
watch: { //Тут мы укажем, за изменением каких файлов мы хотим наблюдать
html: 'app/**/*.html',
js: 'app/js/**/*.js',
scss: 'app/css/**/*.scss',
css: 'app/css/**/*.css',
img: 'app/img/**/*.*',
fonts: 'app/fonts/**/*.*'
},
clean: './dist'
};
var config = {
server: {
baseDir: "./dist"
},
tunnel: true,
host: 'localhost',
port: 8081,
logPrefix: "WAYUP"
};
gulp.task('vendorJs:build', function () {
gulp.src( mainBowerFiles('**/*.js') ) //Выберем файлы по нужному пути
.pipe(gulp.dest(path.vendor.js)) //Выплюнем готовый файл в app
});
gulp.task('vendorCss:build', function () {
gulp.src( mainBowerFiles('**/*.css') ) //Выберем файлы по нужному пути
.pipe(gulp.dest(path.vendor.css)) //И в app
});
gulp.task('html:build', function () {
gulp.src(path.app.html) //Выберем файлы по нужному пути
.pipe(gulp.dest(path.dist.html)) //Выплюнем их в папку build
.pipe(reload({stream: true})); //И перезагрузим наш сервер для обновлений
});
gulp.task('js:build', function () {
gulp.src(path.app.js) //Найдем наш main файл
.pipe(sourcemaps.init()) //Инициализируем sourcemap
.pipe(uglify()) //Сожмем наш js
.pipe(sourcemaps.write()) //Пропишем карты
.pipe(gulp.dest(path.dist.js)) //Выплюнем готовый файл в build
.pipe(reload({stream: true})); //И перезагрузим сервер
});
gulp.task('scss:build', function () {
gulp.src(path.app.scss) //Выберем наш main.scss
.pipe(sourcemaps.init()) //То же самое что и с js
.pipe(sass()) //Скомпилируем
.pipe(prefixer()) //Добавим вендорные префиксы
.pipe(cleanCSS()) //Сожмем
.pipe(sourcemaps.write())
.pipe(gulp.dest(path.dist.scss)) //И в build
.pipe(reload({stream: true}));
});
gulp.task('css:build', function () {
gulp.src(path.app.css) //Выберем наш main.css
.pipe(sourcemaps.init()) //То же самое что и с js
.pipe(gulp.dest(path.dist.css)) //И в build
.pipe(reload({stream: true}));
});
gulp.task('image:build', function () {
gulp.src(path.app.img) //Выберем наши картинки
.pipe(imagemin({ //Сожмем их
progressive: true,
svgoPlugins: [{removeViewBox: false}],
use: [pngquant()],
interlaced: true
}))
.pipe(gulp.dest(path.dist.img)) //И бросим в build
.pipe(reload({stream: true}));
});
gulp.task('fonts:build', function() {
gulp.src(path.app.fonts)
.pipe(gulp.dest(path.dist.fonts))
});
gulp.task('build', [
'vendorCss:build',
'vendorJs:build',
'html:build',
'js:build',
'scss:build',
'css:build',
'fonts:build',
'image:build'
]);
gulp.task('watch', function(){
watch([path.watch.html], function(event, cb) {
gulp.start('html:build');
});
watch([path.watch.scss], function(event, cb) {
gulp.start('scss:build');
});
watch([path.watch.css], function(event, cb) {
gulp.start('css:build');
});
watch([path.watch.js], function(event, cb) {
gulp.start('js:build');
});
watch([path.watch.img], function(event, cb) {
gulp.start('image:build');
});
watch([path.watch.fonts], function(event, cb) {
gulp.start('fonts:build');
});
});
gulp.task('webserver', function () {
browserSync(config);
});
gulp.task('clean', function (cb) {
rimraf(path.clean, cb);
});
gulp.task('default', ['build', 'webserver', 'watch']);
Answer the question
In order to leave comments, you need to log in
gulp.task('watch', function(){
browserSync.init(config);
gulp.watch(path.watch.html, gulp.series('html:build'));
gulp.watch(path.watch.scss, gulp.series('scss:build'));
gulp.watch(path.watch.css, gulp.series('css:build'));
gulp.watch(path.watch.js, gulp.series('js:build'));
gulp.watch(path.watch.images, gulp.series('images:build'));
gulp.watch(path.watch.fonts, gulp.series('fonts:build'));
})
parallel
and series
. That is, in the first case, yours task-и
in the thread are executed together. And in another case, the first one will be executed first task
, then the second, the third and to the end. build
you can do this:gulp.task('build',
gulp.series(
'clean:build',
gulp.parallel(
'html:build',
'css:build',
'js:build',
'images:build',
'fonts:build'
)));
dist
, and then the production is assembled. Didn't find what you were looking for?
Ask your questionAsk a Question
731 491 924 answers to any question