为了账号安全,请及时绑定邮箱和手机立即绑定

node child_process如何打印到控制台?

node child_process如何打印到控制台?

梦里花落0921 2018-09-07 09:11:06
在项目中想使用gulp+webpackwebpack用来打包jsgulp用来复制合并css等资源现在在开发中想gulp和webpack都启动watch模式,监听变化,我用child_process启了一个子进程来执行webpack -w,gulp.task('dev', function() {     gulp.watch('./public/css/*.css', function(e) {        var path = e.path;         gulp.src(path).pipe(gulp.dest(dist + 'public/css'));     });         var child_process = require('child_process');         var workerProcess = child_process.exec('node node_modules/webpack/bin/webpack.js', function() {             console.log(arguments);     })     workerProcess.on('exit', function() {        console.log('exit child');     }) });webpack配置文件已经设置watch: true了,现在能实现我的要求,但是每次webpack打包的信息没法输出到控制台了,谁能指导一下吗?对Node不太懂。
查看完整描述

1 回答

?
素胚勾勒不出你

TA贡献1827条经验 获得超9个赞

var workerProcess = child_process.exec('node node_modules/webpack/bin/webpack.js', function(error, stdout, stderr) {

    if (error) {

      console.error('exec error: '+error)

      return

    }

    console.log('stdout: '+stdout)

    console.log('stderr: '+stderr)

})

但是请注意,exec方法默认的最大允许输出到stdout和stderr的数据量不超过200K,如果超过了,子进程就会被杀死。请注意!!!(可以改用spawn避免该问题,或者手动设置maxBuffer),或者直接使用下面的代码

var workerProcess = child_process.exec('node node_modules/webpack/bin/webpack.js', {})


workerProcess.stdout.on('data', function (data) {

    console.log('stdout: ' + data);

});


workerProcess.stderr.on('data', function (data) {

    console.log('stderr: ' + data);

});

虽然在node的文档用法中,spwan和exec的最终回调方式有区别,但是在node的实现中,其实两者的实现方式是一致的,exec也可以像spawn一样使用,只不过exec在触发stderr和stdout的data事件的时候,会把数据写到字符串中,到执行结束或者错误退出的时候通过回调函数传递出来,实现了exec上面这种便捷用法。

查看完整回答
反对 回复 2018-10-14
  • 1 回答
  • 0 关注
  • 1869 浏览
慕课专栏
更多

添加回答

代码语言

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号