无法让 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
};
使用 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
};