"process.stdout. "在node.js中写入“和”console.log“?
EDIT:使用console.log作为变量显示了许多不可读的字符,而使用process.stdout.write显示了一个对象。
为什么呢?
"process.stdout. "在node.js中写入“和”console.log“?
EDIT:使用console.log作为变量显示了许多不可读的字符,而使用process.stdout.write显示了一个对象。
为什么呢?
当前回答
查看Node文档,显然console.log只是process.stdout.write,在结尾加一个换行符:
console.log = function (d) {
process.stdout.write(d + '\n');
};
来源:http://nodejs.org/docs/v0.3.1/api/process.html process.stdout
其他回答
对于那些喜欢Deno的人,我可以通过使用下面的ANSI转义序列和Deno版本的process.stdout.write来实现这一点。
ESC[2K clears entire line
ESC[#G moves cursor to column #
Code
/*
Console.log() to the same line
Supported in Deno 1.8.1
*/
const myTextEncoder : TextEncoder = new TextEncoder();
let counter : number = 0;
while(counter < 100000) {
// ESC[2K clears entire line
await Deno.stdout.write(myTextEncoder.encode(`\x1b[2K`));
// ESC[#G moves cursor to column #
await Deno.stdout.write(myTextEncoder.encode(`\x1b[0G`));
// OUTPUT incremented counter
await Deno.stdout.write(myTextEncoder.encode(`COUNTER: ${counter++}`));
}
Console.log()使用格式化输出调用process.stdout.write。具体实现请参见console.js中的format()。
目前(v0.10.ish):
Console.prototype.log = function() {
this._stdout.write(util.format.apply(this, arguments) + '\n');
};
Console.log()每次调用它都会添加大量内容和新行
Process.stdout.write()只是纯文本,没有格式
至少我是这么被教导的
简单的区别是: Console.log()方法自动添加新的行字符。这意味着如果我们循环遍历并打印结果,每个结果将在新行中打印。
Process.stdout.write()方法不会追加新的行字符。适用于打印图案。
实现process.sdout。Write, process. sout . Write是一个直接输出到控制台的缓冲区/流。
根据我的puglin serverline: console = new console (consoleOptions),您可以用自己的readline系统重写console类。
你可以看到console.log的源代码:
第十四节。X - lib/internal/console/constructor.js; 对于旧版本:v10.0.0 - lib/console.js。
更多信息:
readline。创建你的自定义行为或使用控制台输入。