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 相关文章推荐
JS处理VBArray的函数使用说明
May 11 Javascript
Javascript 修改String 对象 增加去除空格功能(示例代码)
Nov 30 Javascript
JavaScript实现动态添加,删除行的方法实例详解
Jul 02 Javascript
JavaScript中的跨浏览器事件操作的基本方法整理
May 20 Javascript
javascript将list转换成树状结构的实例
Sep 08 Javascript
基于es6三点运算符的使用方法(实例讲解)
Oct 12 Javascript
webpack+vue2构建vue项目骨架的方法
Jan 09 Javascript
vue做移动端适配最佳解决方案(亲测有效)
Sep 04 Javascript
简单了解JavaScript中的执行上下文和堆栈
Jun 24 Javascript
jsonp格式前端发送和后台接受写法的代码详解
Nov 07 Javascript
简单了解JavaScript弹窗实现代码
May 07 Javascript
jQuery 常用特效实例小结【显示与隐藏、淡入淡出、滑动、动画等】
May 19 jQuery
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_Cooikes不同页面无法传递的解决方法
2014/03/07 PHP
百万级别知乎用户数据抓取与分析之PHP开发
2015/09/28 PHP
php数据访问之查询关键字
2016/05/09 PHP
jQuery 源码分析笔记(7) Queue
2011/06/19 Javascript
JS无法捕获滚动条上的mouse up事件的原因猜想
2012/03/21 Javascript
jQuery常见开发技巧详细整理
2013/01/02 Javascript
jquery的ajaxSubmit()异步上传图片并保存表单数据演示代码
2013/06/04 Javascript
jquery实现鼠标滑过后动态图片提示效果实例
2015/08/10 Javascript
javascript判断firebug是否开启的方法
2016/11/23 Javascript
JavaScript无阻塞加载和defer、async详解
2017/02/26 Javascript
javascript基本数据类型和转换
2017/03/17 Javascript
nuxt.js 缓存实践
2018/06/25 Javascript
解决Vue-cli npm run build生产环境打包,本地不能打开的问题
2018/09/20 Javascript
原生js实现日期选择插件
2020/05/21 Javascript
[02:02]DOTA2英雄基础教程 斯拉达
2013/12/11 DOTA
[06:11]2014DOTA2国际邀请赛 专访团结一心的VG战队
2014/07/21 DOTA
python使用MySQLdb访问mysql数据库的方法
2015/08/03 Python
Python3处理HTTP请求的实例
2018/05/10 Python
python3将视频流保存为本地视频文件
2018/06/20 Python
Python 删除整个文本中的空格,并实现按行显示
2018/07/24 Python
使用Django2快速开发Web项目的详细步骤
2019/01/06 Python
bluepy 一款python封装的BLE利器简单介绍
2019/06/25 Python
python 实现12bit灰度图像映射到8bit显示的方法
2019/07/08 Python
在Sublime Editor中配置Python环境的详细教程
2020/05/03 Python
python3跳出一个循环的实例操作
2020/08/18 Python
Python lxml库的简单介绍及基本使用讲解
2020/12/22 Python
HTML5表格_动力节点Java学院整理
2017/07/11 HTML / CSS
微软日本官方网站:Microsoft日本
2017/11/26 全球购物
Abbott Lyon官网:女士手表、珠宝及配件
2020/12/26 全球购物
金融专业毕业生推荐信
2013/11/26 职场文书
前台文员岗位职责
2013/12/28 职场文书
物流合作计划书
2014/01/10 职场文书
生日寄语大全
2014/04/08 职场文书
房屋出售协议书
2014/04/10 职场文书
自主招生学校推荐信
2014/09/26 职场文书
vue中data改变后让视图同步更新的方法
2021/03/29 Vue.js