Node.js REPL(交互式解释器)

Node.js 中 REPL 表示一个电脑的环境,类似 Window 系统的终端或 Unix/Linux shell,我们可以在终端中输入命令,并接收系统的响应。 Node 自带了交互式解释器,可以执行以下任务:

Node 自带了交互式解释器,可以执行以下任务:

  • 读取:读取用户输入,解析输入了Javascript 数据结构并存储在内存中。
  • 执行 :执行输入的数据结构。
  • 打印 :输出结果。
  • 循环 :循环操作以上步骤直到用户两次按下 Ctrl-c按钮退出。

repl模块介绍

repl模块提供了一种“读取-求值-输出”循环的实现,可以作为一个独立的程序或嵌入到其他应用中。

repl模块的引入方式如下所示:

const repl = require('repl');

repl 模块导出了 repl.REPLServer 类,当 repl.REPLServer 实例运行时,它接收用户输入的每一行,根据用户定义的解释函数解释这些输入,然后输出结果。输入可以是 stdin,输出可以是 stdout,或者也可以连接到其他任何 Node.js 流。

repl.REPLServer 实例支持输入的自动补全、精简 Emacs 风格的行编辑、多行输入、ANSI 风格的输出、当前 REPL 会话状态的保存与恢复、错误校正、以及可定制的解释函数。

命令与特殊键

所有 REPL 的实例都支持下列特殊命令:

  • .break :在输入一个多行表达式的过程中,输入 .break 命令将终止表达式的继续输入。
  • .clear : 重置 REPL 的 context 为一个空对象,并清除当前正输入的所有多行表达式。
  • .exit:关闭输入输出流,退出 REPL。
  • .help :显示特定命令的帮助列表。
  • .save :保存当前 REPL 会话到一个文件。
  • .load:读取一个文件到当前 REPL 会话。
  • .editor:进入编辑模式(<ctrl>-D 完成, <ctrl>-C 取消)。

REPL 中下列按键组合有特殊作用:

  • <ctrl>-C :当按下一次时,与 .break 命令的效果一样。当在空白行按下两次时,与 .exit 命令的效果一样。
  • <ctrl>-D :与 .exit 命令的效果一样。
  • <tab> :当在空白行按下时,显示全局和本地作用域内的变量。当在输入时按下,显示相关的自动补全选项。

简单的表达式运算

我们可以在Node.js REPL的命令行窗口执行简单的数学运算。

示例:

例如向命令窗口输入node命令,按下回车键,就可以在里面进行数学运算啦:

$ node
> 1+2
3

>10-(5*2)+3
3

大家自己试一下呀,比较简单,所以这里就不上效果图了。

使用变量

在 REPL 的命令行窗口声明变量需要使用 var 关键字,如果没有使用 var 关键字则会直接打印出来。

想要输出变量的值可以使用 console.log()方法。

示例:
$node
> var a = 1
undefined

> a = 1
1

> console.log(a)
1
undefined

默认的解释器会把最近一次解释的表达式的结果赋值给变量 _ (下划线)。 显式地设置 _ 为某个值能禁用该特性。

$node
>5
5
>_ + 6
11

>1+1
2
>_
2

多行表达式使用

Node REPL 支持输入多行表达式。

示例
$node
>a = 1
>if (a = 1){
...console.log(a)
...}
1
undefined    

上述代码中三个点的符号是系统自动生成的,需要换行直接按回车就可以,Node 会自动检测是否为连续的表达式。

REPLServer 类中的事件的使用

exit事件

当接收到 .exit 命令、或按下两次 <ctrl>-C 发出 SIGINT 信号、或按下 <ctrl>-D 发出 'end' 信号而使 REPL 被退出时,触发 'exit' 事件。 监听器的回调函数被调用时不带任何参数。

replServer.on('exit', () => {
  console.log('exit事件');
  process.exit();
});
reset事件

当 REPL 的上下文被重置时,触发 'reset' 事件。每当接收到 .clear 命令时会触发该事件,除非 REPL 正在使用默认的解释器并且 repl.REPLServer 实例被创建时 useGlobal 选项被设为 true。 监听器的回调函数被调用时会带上 context 对象作为惟一的参数。

var repl = require('repl');

function initializeContext(context) {
  context.x = 'test';
}

var r = repl.start({ prompt: '> ' });
initializeContext(r.context);

r.on('reset', initializeContext);

当代码被执行时,全局的 'x' 变量可以被修改,但随后的 .clear 命令会把它重置回初始值:

> node test.js
>x
'test'
> x = 5
5
>x
5
> .clear
Clearing context...
> x
'test'
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,734评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,931评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,133评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,532评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,585评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,462评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,262评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,153评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,587评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,792评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,919评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,635评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,237评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,855评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,983评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,048评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,864评论 2 354

推荐阅读更多精彩内容