node.js学习之交互式解释器REPL详解


Posted in Javascript onDecember 08, 2016

简介

repl是Node.js提供的一个Read-Eval-Print-Loop (REPL,读取-执行-输出-循环)实现,它即可以做为一个独立的程序使用,又可以包含在其它应用中使用。REPL是一个互式命令行解析器,它提供了一个交互式的编程环境,它可以实时的验证你所编写的代码,非常适合于验证Node.js和JavaScript的相关API。

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

     读取 - 读取用户输入,解析输入了Javascript 数据结构并存储在内存中。

     执行 - 执行输入的数据结构

     打印 - 输出结果

     循环 - 循环操作以上步骤直到用户两次按下 ctrl-c 按钮退出。

Node 的交互式解释器可以很好的调试 Javascript 代码。

REPL既可以作为独立单机程序,也可以被其他的程序包含在内的程序。

它提供了一种交互方式,即“执行程序,展现结果”。

它可以被用作debugging,testing 或者只是执行操作得到一些结果。

执行REPL

打开命令行,到达node.js安装的目录,键入node

$ node
>

会看到REPL命令提示符>在这里你可以输入任何Node.js的命令。

1)、简单表达式

让我们尝试在Node.js的REPL命令提示符下完成简单的数学计算:

$ node
> 2 + 3
> 2 + ( 2 * 3 ) - 4
>

注意: > 是REPL命令的提示符。

2)、使用变量

你可以将数据存储在变量中,并在你需要的使用它。

变量声明需要使用 var 关键字,如果没有使用 var 关键字变量会直接打印出来。

使用 var 关键字的变量可以使用 console.log() 来输出变量。

$ node
> x = 10
> var y = 10
undefined
> x + y
> console.log("Hello World")
Hello World
undefined

3)、多行表达式

Node REPL 支持输入多行表达式,这就有点类似 JavaScript。

接下来让我们来执行一个 do-while 循环:

$ node
> var x = 0
undefined
> do {
... x++;
... console.log("x: " + x);
... } while ( x < 5 );
x: 1
x: 2
x: 3
x: 4
x: 5
undefined
>

... 三个点的符号是系统自动生成的,你回车换行后即可。Node 会自动检测是否为连续的表达式。

4)、使用函数

> var name="aaa"
undefined
> name
'aaa'
> function getName(){
... console.log(this.name);
... }
undefined
> getName()
aaa
undefined

因为REPL环境内部使用eval函数来评估该表达式的执行结果,所以有些东西我们可以直接这样写,如对象:

> {a:1,b:2}
{ a: 1, b: 2 }

> [1,2,3,4,5]
[ 1, 2, 3, 4, 5 ]

5)、下划线_

使用_可以指代上一次的操作执行后的值,比如

对象:

> {a:2,b:3}
{ a: 2, b: 3 }
> for(var key in _){
... console.log("key="+key+",value="+_[key]);
... }
key=a,value=2
key=b,value=3
undefined

数组:

> {a:2,b:3}
{ a: 2, b: 3 }
> for(var key in _){
... console.log("key="+key+",value="+_[key]);
... }
key=a,value=2
key=b,value=3
undefined

正确的结果:

> [1,2,3,4,5]
[ 1, 2, 3, 4, 5 ]   //数组
> Object.keys(_).map(function(k){return _[k]*_[k]})
[ 1, 4, 9, 16, 25 ]   //元素值

3、REPL命令

ctrl + c - 终止当前命令

ctrl + c twice - 终止Node REPL

ctrl + d - 终止Node REPL

Up/Down Keys - 查看命令历史记录和修改以前的命令

tab Keys - 当前指令的列表

help - 所有命令的列表

break - 退出多行表达式

clear - 从多行表达退出

save filename - 当前Node REPL会话保存到文件中

load filename - 加载文件的内容在当前Node REPL会话

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
特殊字符、常规符号及其代码对照表
Jun 26 Javascript
jQuery中fadeOut()方法用法实例
Dec 24 Javascript
JQuery实现的按钮倒计时效果
Dec 23 Javascript
jQuery中Find选择器用法示例
Sep 21 Javascript
详解jQuery事件
Jan 13 Javascript
Vue form 表单提交+ajax异步请求+分页效果
Apr 22 Javascript
Angularjs2不同组件间的通信实例代码
May 06 Javascript
详解ionic本地相册、拍照、裁剪、上传(单图完全版)
Oct 10 Javascript
通过函数作用域和块级作用域看javascript的作用域链
Aug 05 Javascript
使用vuex存储用户信息到localStorage的实例
Nov 11 Javascript
vue-socket.io跨域问题有效解决方法
Feb 11 Javascript
JavaScript Dom实现轮播图原理和实例
Feb 19 Javascript
JavaScript正则表达式小结(test|match|search|replace|split|exec)
Dec 08 #Javascript
JS中用childNodes获取子元素换行会产生一个子元素
Dec 08 #Javascript
微信公众号 摇一摇周边功能开发
Dec 08 #Javascript
Vue概念及常见命令介绍(1)
Dec 08 #Javascript
Jquery给当前页或者跳转后页面的导航栏添加选中后样式的实例
Dec 08 #Javascript
jquery二级目录选中当前页的css样式
Dec 08 #Javascript
wap手机端解决返回上一页的js实例
Dec 08 #Javascript
You might like
PHP入门学习的几个不错的实例代码
2008/07/13 PHP
PHP 5.3 下载时 VC9、VC6、Thread Safe、Non Thread Safe的区别分析
2011/03/28 PHP
php搜索文件程序分享
2015/10/30 PHP
gearman中任务的优先级和返回状态实例分析
2020/02/27 PHP
js 效率组装字符串 StringBuffer
2009/12/23 Javascript
js 点击按钮弹出另一页,选择值后,返回到当前页
2010/05/26 Javascript
js中substring和substr的详细介绍与用法
2013/08/29 Javascript
js中call与apply的用法小结
2013/12/28 Javascript
js判断浏览器类型为ie6时不执行
2014/06/15 Javascript
node.js中的fs.fsync方法使用说明
2014/12/15 Javascript
JavaScript实现添加及删除事件的方法小结
2015/08/04 Javascript
谈谈js中的prototype及prototype属性解释和常用方法
2015/11/25 Javascript
jQuery下拉菜单的实现代码
2016/11/03 Javascript
bootstrap使用validate实现简单校验功能
2016/12/02 Javascript
JavaScript表单验证实现代码
2017/05/22 Javascript
微信小程序request请求后台接口php的实例详解
2017/09/20 Javascript
[01:21]DOTA2 新英雄 森海飞霞
2020/12/18 DOTA
跟老齐学Python之有容乃大的list(2)
2014/09/15 Python
Python中的zipfile模块使用详解
2015/06/25 Python
Python处理PDF及生成多层PDF实例代码
2017/04/24 Python
Python3.5字符串常用操作实例详解
2019/05/01 Python
python模拟菜刀反弹shell绕过限制【推荐】
2019/06/25 Python
python如何制作英文字典
2019/06/25 Python
python切片的步进、添加、连接简单操作示例
2019/07/11 Python
python字符串,元组,列表,字典互转代码实例详解
2020/02/14 Python
python 实现简单的计算器(gui界面)
2020/11/11 Python
CSS3 3D位移translate效果实例介绍
2016/05/03 HTML / CSS
美国马匹用品和骑马配件购物网站:Horse.com
2018/01/08 全球购物
医学院学生的自我评价分享
2013/11/19 职场文书
中专毕业生自我鉴定
2014/02/02 职场文书
升旗仪式主持词
2014/03/19 职场文书
党员干部承诺书
2014/03/25 职场文书
2014党员学习习主席讲话思想汇报
2014/09/15 职场文书
大学生见习报告总结
2014/11/04 职场文书
党组织关系的介绍信模板
2019/06/21 职场文书
Ajax实现异步加载数据
2021/11/17 Javascript