我想在未来的项目中使用Gulp,但对我来说更重要的是将 Three.js 模块化功能添加到项目中,使用普通插件示例uglify我没有任何问题,但是当我在我的js代码中运行我的gulp文件时,总是错误THREE未定义,或者如果我输入
var THREE = require('three');
它表示未定义require,如果我添加导入,则相同
从“三个”导入*为三个;
导入未定义
希望我能正确表达我的问题。
这是我的Gulpfile .-
// Include gulp
var gulp = require('gulp');
// Include Our Plugins
var jshint = require('gulp-jshint');
var sass = require('gulp-sass');
var concat = require('gulp-concat');
var uglify = require('gulp-uglify');
var rename = require('gulp-rename');
var THREE = require('three');
gulp.task('build', () =>
gulp.src('app.js')
.pipe(bro({
transform: [
babelify.configure({ presets: ['es2015'] }),
[ 'uglifyify', { global: true } ]
]
})
.pipe(gulp.dest('dist')
)))
gulp.watch('*.js', ['build'])
// Lint Task
gulp.task('lint', function() {
return gulp.src('js/*.js')
.pipe(jshint())
.pipe(jshint.reporter('default'));
});
// Compile Our Sass
gulp.task('sass', function() {
return gulp.src('scss/*.scss')
.pipe(sass())
.pipe(gulp.dest('dist/css'));
});
// Concatenate & Minify JS
gulp.task('scripts', function() {
return gulp.src('js/*.js')
.pipe(concat('all.js'))
.pipe(gulp.dest('dist'))
.pipe(rename('all.min.js'))
.pipe(uglify())
.pipe(gulp.dest('dist/js'));
});
// Watch Files For Changes
gulp.task('watch', function() {
gulp.watch('js/*.js', ['lint', 'scripts']);
gulp.watch('scss/*.scss', ['sass']);
});
// Default Task
gulp.task('default', ['lint', 'sass', 'scripts', 'watch', 'build']);
编辑:想想我明白了,一个网站的文档还没有完整,我也不知道我必须安装Browserify也使用gulp-bro,这似乎是相同的,无论如何修复了需求问题。 (带来其他新的)谢谢你的一切,并希望这有助于某人。
EDIT2 :现在我发现Rollup.js是一个更好的解决方案,Babel,theres Rollup npm s,祝你好运。 谢谢。