0

我对 Grunt 很陌生,所以这可能是一个非常基本的问题。我有一个看起来像这样的 Gruntfile.js:

/*global module:false*/ 
module.exports = function (grunt) { 

  grunt.initConfig({ 

  }); 

  grunt.registerTask('default', 'measureText'); 

  grunt.registerTask('measureText', 'Measures size of text', function() { 
    grunt.log.writeln('========================================================================'); 
    grunt.log.writeln('= output of ImageMagick should be on next line:                        ='); 
    var im = require("node-imagemagick"); 

    im.identify(['-format', '%wx%h', 'build/text.png'], function(err, output){ 
      if (err) throw err; 
      console.log('dimension: '+output);  // <-- NOTHING WRITTEN!
    }); 

    grunt.log.writeln('========================================================================'); 
    return; 
  });    
}; 

如您所见,它调用node-imagemagick方法 identify 来获取图像的宽度和高度(build/text.png)。当我在上面运行我的 grunt 脚本时, identify() 回调没有输出。(这是上面的 console.log 行)。

然而,如果我创建一个 Node 脚本(例如 test-node-imagemagick.js)来测试相同的代码,它就可以正常工作,例如

#!/usr/bin/env node

var im = require("node-imagemagick");
im.identify(['-format', '%wx%h', 'build/text.png'], function(err, output){
  if (err) throw err;
  console.log('dimension: '+output);
});

那么如何从 Grunt 任务中调用 Node 包并获取返回值呢?

顺便说一句,我确实通过以下方式安装了软件包:

$ npm install node-imagemagick

...来自包含 Gruntfile.js 的目录。

谢谢!

4

3 回答 3

0

做一些更多的研究,我能够得到这个工作。首先,我会切换到 imagemagick 开发人员 README 推荐的这个库。

https://github.com/aheckmann/gm

但是,如果您想使用未维护的库,这取决于您。

无论如何,它是:

grunt.registerTask('measureText', function(done) {
  //omitting code

  var done = this.async() //create async task

  im.identify('/path/to/image', function(err, output){
   //do async stuff
   console.log('dimension: %s', output)
   done()
  })

  //or use gm
  gm('/path/to/image')
   .size(function(err, size) {
      console.log('gm size: %s', size)
      done()
   })
})
于 2015-02-19T17:52:27.387 回答
0

编辑:

你的任务永远不会完成的原因是因为你最后的回报模棱两可:

return; <---

您正在中断对以下内容的异步调用:

im.identify(function(){
  //do async
})

return; //exit task

尝试这个:

grunt.registerTask('measureText', function(done) {
    //omitting code

    im.identify(function(){
       //do async stuff

       done()
    })
})

函数参数done()告诉任务运行器它应该在您执行异步操作后完成,而不是在任何代码执行之前结束。

原来的:

您的要求在每个脚本中看起来都非常不同。

require('imagemagick')

--- vs ---

require('node-imagemagick')

Grunt 可能正在吞下错误

另外,我认为它只是:

npm install imagemagick
于 2015-02-19T02:06:57.593 回答
0

我刚刚通过更多挖掘找到了答案,在这里:Using a node module within a Grunt Task failed

基本上,如果要接收回调,我的 Grunt 任务必须是异步的:

/*global module:false*/ 
module.exports = function (grunt) { 
  var im = require("node-imagemagick"); 


  grunt.initConfig({ 
  }); 

  grunt.registerTask('default', 'measureText'); 

  grunt.registerTask('measureText', 'Measures size of text', function() { 
    var done = this.async(); // <-- Make the task asynchronous!
    grunt.log.writeln('========================================================================'); 
    grunt.log.writeln('= output of ImageMagick should be on next line:                        ='); 

    im.identify(['-format', '%wx%h', 'build/text.png'], function(err, output){ 
      if (err) throw err; 
      console.log('dimension: '+output); 
      done();
    });  
  });    
}; 

当然,这意味着如果我将第二行保留在那里,输出实际上不会出现在两行等号之间。

于 2015-02-19T16:57:48.727 回答