javascript - 任务从未定义 : Moving from gulpV3 to gulpV4

标签 javascript npm sass gulp gulp-4

我不得不将一个旧项目从 gulp 版本 3.9.1 升级到 gulp 版本 4,这需要我重写我的任务。我已经按照文档移动到 gulp.series 并移动到名称函数,但我现在仍然在运行时遇到错误。下面是我用来查看两种不同语言样式的代码。

var fontName = "project-icons",
    gulp = require("gulp"),
    sass = require("gulp-sass"),
    sourcemaps = require("gulp-sourcemaps"),
    iconfont = require("gulp-iconfont"),
    iconfontCss = require("gulp-iconfont-css");

var sassOptions = {
    errLogToConsole: true,
    outputStyle: "expanded"
};

function iconfont(done) {
    gulp.src(["./icons/*.svg"])
        .pipe(
            iconfontCss({
                fontName: fontName,
                path: "sass",
                targetPath: "../sass/static/icons/_icons.sass",
                fontPath: "./fonts/",
                cssClass: "icon"
            })
        )
        .pipe(
            iconfont({
                formats: ["ttf", "eot", "woff", "woff2", "svg"],
                fontName: fontName,
                normalize: true,
                fixedWidth: true,
                centerHorizontally: true
            })
        )
        .on("glyphs", function(glyphs, options) {})
        .pipe(gulp.dest("./fonts/"));
    done();
}

function desktop_styles() {
    return gulp
        .src("./sass/_en/style.sass")
        .pipe(
            sourcemaps.init({
                loadMaps: true,
                identityMap: true,
                sourceRoot: "../css/"
            })
        )
        .pipe(sass(sassOptions).on("error", sass.logError))
        .pipe(sourcemaps.write())
        .pipe(gulp.dest("./css/"));
}

function desktop_styles_rtl() {
    return gulp
        .src("./sass/_ar/style.sass")
        .pipe(
            sourcemaps.init({
                loadMaps: true,
                identityMap: true,
                sourceRoot: "../css/"
            })
        )
        .pipe(sass(sassOptions).on("error", sass.logError))
        .pipe(sourcemaps.write())
        .pipe(gulp.dest("./css/lang/rtl"));
}

function mobile_styles() {
    return gulp
        .src("./sass/en/mobile/style.sass")
        .pipe(sass(sassOptions).on("error", sass.logError))
        .pipe(gulp.dest("./css/m"));
}

function mobile_styles_rtl() {
    return gulp
        .src("./sass/rtl/m/style.sass")
        .pipe(sass(sassOptions).on("error", sass.logError))
        .pipe(gulp.dest("./css/lang/rtl/m"));
}

function watch_all(){
    gulp.series(
        mobile_styles,
        mobile_styles_rtl,
        desktop_styles,
        desktop_styles_rtl,
        function(done) {
            gulp.watch("./sass/**/*.sass", gulp.series(mobile_styles));
            gulp.watch("./sass/**/*.sass", gulp.series(mobile_styles_rtl));
            gulp.watch("./sass/**/*.sass", gulp.series(desktop_styles));
            gulp.watch("./sass/**/*.sass", gulp.series(desktop_styles_rtl));
            done();
        }
    )
};

function watch_AllDesktop(done){
    gulp.series(desktop_styles, desktop_styles_rtl, function() {
        gulp.watch("./sass/**/*.sass", gulp.series(desktop_styles));
        gulp.watch("./sass/**/*.sass", gulp.series(desktop_styles_rtl));
        done();
    });

function watch_desk_desktop_styles_rtl(done){
    gulp.series(desktop_styles_rtl, function() {
        gulp.watch("./sass/**/*.sass", gulp.series(desktop_styles_rtl));
        done();
    });

function watch_desktop_en(done){
    gulp.series(desktop_styles, function() {
        gulp.watch("./sass/**/*.sass", gulp.series(desktop_styles));
    });

function watch_mobile_rtl(done){
    gulp.series(mobile_styles_rtl, function() {
        gulp.watch("./sass/**/*.sass", gulp.series(mobile_styles_rtl));
        done();
    });

function watch_mobile_en(done){
    gulp.series(mobile_styles, function() {
        gulp.watch("./sass/**/*.sass", gulp.series(mobile_styles));
        done();
    });

function watch_AllMobile(done){
    gulp.series(mobile_styles, mobile_styles_rtl, function() {
        gulp.watch("./sass/**/*.sass", gulp.series(mobile_styles));
        gulp.watch("./sass/**/*.sass", gulp.series(mobile_styles_rtl));
        done();
    });

当我运行“gulp watch_all”时,我得到任务从未定义。功能或我的代码顺序有问题吗?

最佳答案

  1. watch_AllDesktopwatch_AllMobile 的所有功能都需要一个右括号 }

  2. 你的主要问题是,你没有导出你的任务


实习生任务无需导出,但您的所有任务(应可在每个控制台上运行)都必须导出。

例如将以下导出放在 gulpfile.js 的末尾:

exports.watch_all = watch_all;


导出后,您可以使用 gulp --tasks 证明您可以使用哪些任务


编辑(评论问题)

你的 watch 应该没有回调,因为 watch 应该永久运行而不是只有一次。

function watch_all(){
    gulp.watch("./sass/**/*.sass", gulp.series(mobile_styles, mobile_styles_rtl, desktop_styles, desktop_styles_rtl ));
}

如有其他问题,请使用小示例和受影响的代码打开新问题。谢谢

关于javascript - 任务从未定义 : Moving from gulpV3 to gulpV4,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55273876/

相关文章:

node.js - Node 6 调试器窗口 - 尝试复制 OSX 应用程序图标以自定义电子预构建时出错

node.js - 弃用警告 : Buffer() is deprecated due to security and usability issues when I move my script to another server

javascript - 将 react-css-modules 与 sass 一起使用不起作用

css - 样式应该在哪里使用react?

sass - 使用 SublimeLinter-scss-lint 和 Sublime TExt 忽略某些错误

javascript - Express.js res.render 和 res.json

javascript - 在重力形式计算中使用指数

javascript - .babelrc 中指定的未知插件 "static-fs"?

javascript - 如何在我的网站上添加 Facebook 分享按钮?

javascript - 使 gs 文件既作为应用程序脚本文件又作为客户端 js 文件