我一直在寻找这个,但没有运气。
我正在尝试编写一个 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,而不是所有文件。
有什么帮助吗?谢谢
我的帮助并不简单,但从长远来看可能会更好。我建议不要重新发明轮子,而是使用经过验证的软件包进行移动应用程序开发。有一个很棒的Yeoman Geneator,它将从头开始提供一个离子启动器项目,包括所有附加功能,如大口缩小:generator-m-ionic
最后,我以这种方式解决了:
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
除了 ionic 文件夹中的任何文件。我只是决定将我唯一需要的文件直接复制到我的 src 文件夹中,这让我的生活更轻松。
希望对您有所帮助。