2

我一直在为此寻找一段时间,但没有运气。

我正在尝试编写一个 gulp 任务,该任务应该连接我的 lib 文件夹中的所有 js 文件,除了一些文件。

我尝试了以下方法,使用 gulp-ignore,但没有运气:

var gulpIgnore = require('gulp-ignore');

var ignoreIonic = '!./www/lib/ionic/';

gulp.task('unify-libs', function () {
    gulp.src(paths.libs)
        .pipe(sourcemaps.init())
        .pipe(ngAnnotate({
            single_quotes: true
        }))
        .pipe(gulpIgnore.exclude(ignoreIonic))
        .pipe(concat('libs.js'))
        .pipe(uglify())
        .pipe(sourcemaps.write())
        .pipe(gulp.dest('./src/js'));
});

我的文件夹结构如下:

www
 |--lib
    |--ionic
    |   |--css
    |   |--fonts
    |   |--js
    |   |   |--angular
    |   |   |--angular-ui
    |   |   |--ionic.bundle.js
    |   |   |--ionic.bundle.min.js
    |   |   |--ionic.js
    |   |   |--ionic.min.js
    |   |   |--ionic-angular.js
    |   |   |--ionic-angular.min.js
    |   |--scss
    |--test.js

我试图通过 gulp 任务实现的是:

我想连接lib 文件夹中的所有文件,但在 ionic->js 中我只想将ionic.bundle.min.js连接到最终的 javascript 而不是所有文件。

有什么帮助吗?谢谢

4

2 回答 2

1

我的帮助并不简单,但从长远来看可能会更好。我建议不要重新发明轮子,而是使用经过验证的包来开发移动应用程序。那里有一个很棒的Yeoman Geneator,它将从头开始提供一个离子启动项目,其中包括 gulp 缩小等所有附加功能: generator-m-ionic

于 2016-02-03T15:20:25.263 回答
1

最后,我以这种方式解决了:

var paths = {
    libs: ['./www/lib/**/*.js', '!./www/lib/ionic/**'],
    ....
};

gulp.task('unify-libs', function () {
    gulp.src(paths.libs)
        .pipe(sourcemaps.init())
        .pipe(ngAnnotate({single_quotes: true}))
        .pipe(concat('libs.js'))
        .pipe(uglify())
        .pipe(sourcemaps.write())
        .pipe(gulp.dest('./src/' + appRelease + '/js'));
});

它现在正在编译文件lib夹内的所有文件,除了离子文件夹内的任何文件。我刚刚决定将我需要的唯一文件直接复制到我的 src 文件夹中,这让我的生活更轻松。

希望能帮助到你。

于 2016-02-04T15:21:56.317 回答