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 相关文章推荐
fancybox1.3.1 基于Jquery的插件在IE中图片显示问题
Oct 01 Javascript
使用jquery实现图文切换效果另加特效
Jan 20 Javascript
JS运动基础框架实例分析
Mar 03 Javascript
javascript自定义右键弹出菜单实现方法
May 25 Javascript
微信小程序 video组件详解
Oct 25 Javascript
原生js实现新闻列表展开/收起全文功能
Jan 20 Javascript
基于vue2的table分页组件实现方法
Mar 20 Javascript
js数组实现权重概率分配
Sep 12 Javascript
基于 Vue 实现一个酷炫的 menu插件
Nov 14 Javascript
vue-cli2.9.3 详细教程
Apr 23 Javascript
详解Angular Forms中自定义ngModel绑定值的方式
Dec 10 Javascript
jquery实现聊天机器人
Feb 08 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
smarty静态实验表明,网络上是错的~呵呵
2006/11/25 PHP
PHP生成指定长度随机数最简洁的方法
2014/07/14 PHP
ThinkPHP中自定义错误页面和提示页面实例
2014/11/22 PHP
PHP实现简单ajax Loading加载功能示例
2016/12/28 PHP
php中各种定义变量的方法小结
2017/10/18 PHP
FileUpload 控件 禁止手动输入或粘贴的实现代码
2010/04/07 Javascript
jquery可见性过滤选择器使用示例
2013/06/24 Javascript
js中方法重载如何实现?以及函数的参数问题
2013/08/01 Javascript
JS自调用匿名函数具体实现
2014/02/11 Javascript
Nodejs学习笔记之Global Objects全局对象
2015/01/13 NodeJs
javascript递归回溯法解八皇后问题
2015/04/22 Javascript
javascript发送短信验证码实现代码
2015/11/12 Javascript
AngularJS基础 ng-selected 指令简单示例
2016/08/03 Javascript
浅谈jQuery中的eq()与DOM中element.[]的区别
2016/10/28 Javascript
React快速入门教程
2017/01/17 Javascript
AngularJS实现根据不同条件显示不同控件
2017/04/20 Javascript
使用js实现将后台传入的json数据放在前台显示
2018/08/06 Javascript
在 Vue 应用中使用 Netlify 表单功能的方法详解
2019/06/03 Javascript
[49:27]LGD vs OG 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
Python 流程控制实例代码
2009/09/25 Python
跟老齐学Python之有容乃大的list(1)
2014/09/14 Python
Linux 发邮件磁盘空间监控(python)
2016/04/23 Python
Python Nose框架编写测试用例方法
2017/10/26 Python
Tensorflow 实现修改张量特定元素的值方法
2018/07/30 Python
Python一键查找iOS项目中未使用的图片、音频、视频资源
2019/08/12 Python
Python转换itertools.chain对象为数组的方法
2020/02/07 Python
一篇文章带你搞定Ubuntu中打开Pycharm总是卡顿崩溃
2020/11/02 Python
python+selenium实现12306模拟登录的步骤
2021/01/21 Python
浅谈CSS3中的变形功能-transform功能
2017/12/27 HTML / CSS
什么是java序列化,如何实现java序列化
2012/11/14 面试题
总监职责范文
2013/11/09 职场文书
参加招聘会后的感想
2015/08/10 职场文书
祝福语集锦:朋友新店开业祝福语
2019/12/10 职场文书
Python使用openpyxl批量处理数据
2021/06/23 Python
Java基础-封装和继承
2021/07/02 Java/Android
Go语言编译原理之源码调试
2022/08/05 Golang