无法让 figlet 将文本输出到命令行

Cannot get figlet to output text to commandline

使用 figlet 时,我真的很难使用 https://www.npmjs.com/package/figlet 上的默认示例将文本输出到命令行。

我有一个 class,它有一个方法,一旦 运行 应该将一些文本输出到命令行。

我的代码如下所示:

/* eslint-disable no-console */
var figlet = require('figlet');

class Page {

  async run () {
    console.log('figlet start');
    console.log(figlet);
    //console.log(figlet.textSync('Hello World!', 'Standard'));
    figlet('Hello World!', 'Standard', function(err, data) {
      if (err) {
        console.log('Something went wrong...');
        console.dir(err);
        return;
      }
      console.log(data);
    });
    console.log('figlet end');
    process.exit(0);
  }
}

module.exports = {
  Page
};

这个输出是:

[Function: me] {
  text: [Function (anonymous)],
  textSync: [Function (anonymous)],
  metadata: [Function (anonymous)],
  defaults: [Function (anonymous)],
  parseFont: [Function (anonymous)],
  loadFont: [Function (anonymous)],
  loadFontSync: [Function (anonymous)],
  preloadFonts: [Function (anonymous)],
  figFonts: {},
  fonts: [Function (anonymous)],
  fontsSync: [Function (anonymous)]
}
figlet end

如果我取消注释 //console.log(figlet.textSync('Hello World!', 'Standard')); 行,则会显示“Hello world!”两次。

我真的很想知道我做错了什么。我可以从我的命令行 运行 figlet repo 中的示例。

也许我从根本上误解了某些东西,所以了解那是什么会很好。

node.js 是异步的,所以 process.exit(0);figlet 完成之前运行,这显示在输出

如果注释掉process.exit(0);,最后的输出应该是figlet的“hello world”

所以输出实际上在 figlet 的回调中结束,所以你应该把所有东西都移到那里:

/* eslint-disable no-console */
var figlet = require('figlet');

class Page {

  async run () {
    console.log('figlet start');
    console.log(figlet);
    //console.log(figlet.textSync('Hello World!', 'Standard'));
    figlet('Hello World!', 'Standard', function(err, data) {
      if (err) {
        console.log('Something went wrong...');
        console.dir(err);
        return;
      }
      console.log(data);
      console.log('figlet end');      
      process.exit(0);
    });
  }
}

module.exports = {
  Page
};