2016-08-22 68 views
0

我想在我计划在ES6中编写的新项目中使用Google Closure Compiler。我只是试着按照https://www.npmjs.com/package/google-closure-compiler。 我做了npm安装google-closure-compiler之后,我尝试了Grunt或Gulp方法,但都没有为我工作。我只是有一个真正简单的js hello世界类型的文件来测试工作流程。使用Grunt或Gulp进行Closure编译器工作

对于步兵我Gruntfile.js:

module.exports = function(grunt) { 

    require('google-closure-compiler').grunt(grunt); 

    grunt.initConfig({ 
    'closure-compiler': { 
    my_target: { 
     files: { 
     'dest/output.min.js': ['src/js/**/*.js'] 
     }, 
     options: { 
     compilation_level: 'SIMPLE', 
     language_in: 'ECMASCRIPT6_STRICT', 
     language_out: 'ECMASCRIPT5_STRICT', 
     create_source_map: 'dest/output.min.js.map', 
     output_wrapper: '(function(){\n%output%\n}).call(this)\n//# sourceMappingURL=output.min.js.map' 
     } 
    } 
    } 
}); 

当我运行 “咕噜” 我得到:

警告:没有定义无极使用--force继续。 由于警告而中止。

对于咕嘟咕嘟,我也跟着教程,和我的gulpfile.js是这样的:

var gulp = require('gulp'), 
    gutil = require('gulp-util'); 

var Promise = require('es6-promise').Promise; 
var closureCompiler = require('google-closure-compiler').gulp(); 

gulp.task('default', function() { 
    return gulp.src('./src/js/**/*.js', {base: './'}) 
     .pipe(closureCompiler({ 
      compilation_level: 'SIMPLE', 
      warning_level: 'VERBOSE', 
      language_in: 'ECMASCRIPT6_STRICT', 
      language_out: 'ECMASCRIPT5_STRICT', 
      output_wrapper: '(function(){\n%output%\n}).call(this)', 
      js_output_file: 'output.min.js' 
     })).on('error', gutil.log) 
     .pipe(gulp.dest('./dist/js')); 
}); 

当我运行一饮而尽intially下面我跑进没有定义无极错误以及,但在本教程至少我能添加ES6承诺量线来解决最初的问题,但后来我还是得到:

events.js:72 
     throw er; // Unhandled 'error' event 
      ^
Error: not implemented 
    at Readable._read (_stream_readable.js:465:22) 
    at Readable.read (_stream_readable.js:341:10) 
    at Readable.on (_stream_readable.js:720:14) 
    at Readable.pipe (_stream_readable.js:575:10) 
    at Transform.CompilationStream._flush (/<my project directory>/node_modules/google-closure-compiler/lib/gulp/index.js:213:17) 
    at Transform.<anonymous> (_stream_transform.js:130:12) 
    at Transform.g (events.js:180:16) 
    at Transform.emit (events.js:117:20) 
    at finishMaybe (_stream_writable.js:360:12) 
    at endWritable (_stream_writable.js:367:3) 

任何帮助就使得无论是步兵还是咕嘟咕嘟工作?

回答

0

升级您的NodeJS版本。插件假定了原生的Promises支持。它的工作原理与NodeJS 0.12相同。

+0

谢谢@ chad-killingsworth!更新我的NodeJS的确有窍门。之后,我测试了我的ES6文件。虽然我的选项包括language_in:'ECMASCRIPT6_STRICT',language_out:'ECMASCRIPT5_STRICT', 输出似乎没有生成我的ES6,但我注意到在传递给Closure编译器的相同设置中,Gulp正确地将我的代码生成到ES5中正确构造。 –

+0

如果这能解决原来的问题,那么你能接受这个答案吗?这是左侧的复选标记。您需要将此下一个问题作为单独的问题发布。 –

+0

确定检查标记。 –