Задать вопрос
@fitilstep

TypeError: browsersync.init is not a function at browserSync?

Не могу понять, в чем ошибка, почему .init некорректно запускается.

spoiler

let project_folder = 'dist'; 
let source_folder = '#src';

let path = {
    build: {
        html: project_folder + "/",
        css: project_folder + "/css/",
        js: project_folder + "/js/",
        img: project_folder + "/img/",
        fonts: project_folder + "/fonts/"
    },
    src: {
        html: source_folder + "/*.html",
        css: source_folder + "/scss/style.scss",
        js: source_folder + "/js/script.js",
        img: source_folder + "/img/**/*.{jpg,png,svg,gif,ico,webp}",
        fonts: source_folder + "/fonts/*.ttf"
    },
    watch: { 
        html: source_folder + "/**/*.html",
        css: source_folder + "/scss/**/*.scss",
        js: source_folder + "/js/**/*.js",
        img: source_folder + "/img/**/*.{jpg,png,svg,gif,ico,webp}"
    },
    clean: "./" + project_folder + "/" 
};

let { src, dest } = require('gulp'),
    gulp = require('gulp'),
    browsersync = require('browser-sync').create;

function browserSync() {
    browsersync.init({
        server: {
            baseDir: "./" + project_folder + "/"
        },
        port: 3000,
        notify: false
    })
};

function html() {
    return src(path.src.html) 
        .pipe(dest(path.build.html)) 
        .pipe(browsersync.stream())
};

let build = gulp.series(html);
let watch = gulp.parallel(build, browserSync);

exports.build = build;
exports.html = html;
exports.watch = watch;
exports.default = watch;

Результат:
5fe30bc469148026898772.png
  • Вопрос задан
  • 608 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
let { src, dest } = require('gulp'),
    gulp = require('gulp'),
-   browsersync = require('browser-sync').create;
+   browsersync = require('browser-sync').create();
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
@sharelove
Для перезагрузки browser-sync используйте не
.pipe(browsersync.stream())
а
.pipe(browsersync.reload({ stream: true }));
иначе перезагрузка не будет работать
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы