options{Object|string}prompt{string} 要显示的输入提示符。默认值:'> '(末尾有一个空格)。input{stream.Readable} REPL 输入要被读取的可读流。默认值:process.stdin。output{stream.Writable} REPL 输出要被写入的可写流。默认值:process.stdout。terminal{boolean} 如果为true,则指定output应被当作一个 TTY 终端。 默认值: 初始化时检查output流的isTTY属性的值。eval{Function} 当解释每行输入时使用的函数。默认值: JavaScripteval()函数的异步封装。eval函数出错时会返回repl.Recoverable,表明输入不完整并提示用户完成输入。useColors{boolean} 如果为true,则指定默认的writer函数可以在 REPL 输出中包含 ANSI 颜色风格。 如果提供了自定义的writer函数,则该参数无效。 默认值: 如果 REPL 实例的terminal值为true,则检查output流上的颜色支持。useGlobal{boolean} 如果为true,则指定默认的解释函数使用 JavaScriptglobal作为上下文,而不是为 REPL 实例创建一个新的独立的上下文。 在node命令行(node CLI)交互解释器中,这个值为true。 默认值:false。ignoreUndefined{boolean} 如果为true,则指定默认的输出器不会输出命令返回的undefined值。 默认值:false。writer{Function} 在写入到output之前,该函数被调用用来格式化每个命令的输出。 默认值: [util.inspect()]。completer{Function} 可选的函数,用来自定义 Tab 键的自动补全。 详见 [readline.InterfaceCompleter]。replMode{symbol} 一个标志位,指定默认的解释器使用严格模式或默认(sloppy)模式来执行 JavaScript 命令。 可选的值有:repl.REPL_MODE_SLOPPY要使用默认模式解释表达式。repl.REPL_MODE_STRICT要使用严格模式解释表达式。该模式等同于在每个 repl 声明前加上'use strict'。
breakEvalOnSigint{boolean} 当接收到SIGINT时停止解释当前代码,比如当按下 Ctrl+C。 不能与自定义的eval函数同时使用。 默认值:false。preview{boolean} 定义 repl 是否打印自动补全并输出预览。 默认值: 如果使用默认的 eval 函数,则为true,如果使用自定义的 eval 函数,则为false。 如果terminal为假,则没有预览,并且preview的值无效。
- 返回: {repl.REPLServer}
repl.start() 方法创建并启动一个 [repl.REPLServer] 实例。
如果 options 是一个字符串,则它指定了输入提示符:
const repl = require('repl');// 一个 Unix 风格的提示符。repl.start('$ ');
