原文地址: http://www.cnblogs.com/liaoyu/p/js-terminal.html

周末闲着想试试用 JavaScript 模拟命令行交互的功能,希望达到的几个功能点如下:

  1. 基本字符的输入
  2. 光标移动
  3. JS解析命令及相应的异常处理并输出结果
  4. 记住命令历史可通过上下方向键切换
  5. 几个快捷键,比如 Ctrl+L 清屏

实现相关

库依赖: jQueryunderscore.js

初始化的 DOM 结构如下:

<div id="panel-shell">
<div class="output-view">
Welcome to js-terminal, Type "help" for more information.
</div><br /> <div class="shell-view">
<span class="prompt">$</span>&nbsp;<span class="input"><span class="left"></span><span class="cursor blink">&nbsp;</span><span class="right"></span></span>
</div>
</div>

命令输入区由 left cursor right 三个span组成, 注意,这三个span之间不能留有间隙,不然浏览器在显示的时候它们也会有间距。

获取字符输入时使用 keypress 事件:

  1. keydown: 当用户按下键盘上的任意键时触发
  2. keypress: 当用户按下键盘上的字符键时触发
$(document).keypress(function(e) {
if (e.which === 32) { // space
$left.append('&nbsp;');
} else if(e.which !== 13) { // enter
$left.append(String.fromCharCode(e.which));
}
});

注意: jQuery 对获取按下的键对应的ASCII码进行了封装,早期的IE只支持 event.keyCode ,而W3C的标准是 event.which ,所以现在标准的做法也是使用 event.which ,keydown事件获取的keyCode值不区别大小写,例如输入a和A都是65。最后将获取的ASCII值转换成字符使用 String.fromCharCode ,它是一个静态方法。

解析命令时,直接使用 eval, 囧

try {
val_ouput = eval(cmd);
} catch (e) {
val_ouput = '\'' + cmd + '\': command not found';
}

命令执行完毕后,使用 underscore.js 的模版引擎输出结果,模版如下:

var template_output = _.template('<div class="output-view"><span class="prompt"><%= separate %></span>&nbsp;<span class="output<%= error %>"><%= value %></span></div>');
$shell.before(template_output({separate:'&gt;', value:val_ouput, error: err_class}) + '<br />');

将历史命令保存到一个数组里,每次敲回国时将新命令加入到历史记录里,可通过上下方向键进行切换。

使用快捷键 Ctrl+L 进行清屏:

if (e.which === 76 && e.ctrlKey) {   // Ctrl + L
e.preventDefault(); $shell.siblings().remove();
}

最后,来一张效果图 (黑色背景是我的最爱了)

在线演示

参考链接

其实已经存在功能相当完善的JS命令终端库

https://github.com/jcubic/jquery.terminal

https://github.com/sdether/josh.js

JavaScript实现命令行交互的更多相关文章

  1. libvirt 命令行交互工具之virsh

    libvirt是当前主流VM最低层库.IBM PowerVM也不例外,libvirt是深入玩虚拟化必须玩转的东西; 简单测试玩玩libvirt 的virsh命令行交互工具, 你我都知libvirt大体 ...

  2. [转] Java 命令行交互-JCommander

    [From] https://github.com/Sayi/sayi.github.com/issues/32 我喜欢简单,什么是简单?正如若干字符组成的命令行. 有时候我们用Java开发了一个小工 ...

  3. 使用 CliWrap 让C#中的命令行交互举重若轻

    在代码中进行命令行交互是一个很常见的场景, 特别是在一些CI CD 自动化流程中, 在这之前我们会使用 System.Diagnostics.Process API, 现在有一个更灵活的工具 CliW ...

  4. 前端技术之:如何创建一个NodeJs命令行交互项目

    方法一:通过原生的NodeJs API,方法如下:   #!/usr/bin/env node # test.js var argv = process.argv; console.log(argv) ...

  5. flask+script命令行交互工具

    Project name :Flask_Plan templates:templates static:static 首先说,我们flask比django方便的地方是所有的模块都可以自己选,你不喜欢s ...

  6. Nodejs 命令行交互神奇 yargs

    传送门: # example https://github.com/yargs/yargs/blob/master/docs/examples.md # 官网 http://yargs.js.org/ ...

  7. 设置python 命令行交互程序自己主动补齐

    1. 新建Python环境变量配置文件: vim ~/.pystartup # Add auto-completion and a stored history file of commands to ...

  8. 如何用nodejs 开发一个命令行交互工具

    参考地址1 参考地址2 一.npm package.json bin 1.package.json { "name": "test", "versio ...

  9. python 怎么和命令行交互

    http://www.cyberciti.biz/faq/python-run-external-command-and-get-output/ http://stackoverflow.com/qu ...

随机推荐

  1. Floyd-Warshall算法详解(转)

    Floyd-Warshall算法,简称Floyd算法,用于求解任意两点间的最短距离,时间复杂度为O(n^3).我们平时所见的Floyd算法的一般形式如下: void Floyd(){ int i,j, ...

  2. [转]在SQLServer中实现Sequence的高效方法

    如果在ORACLE里面用惯了Sequence的兄弟们,要在SqlServer里实现Sequence,就会发现没有现成的Sequence对象可以Create了.那应该怎么办呢? 当然这点小问题是难不倒我 ...

  3. zabbix数据存储

    一.zabbix数据库 zabbix-server将采集到的数据存储在数据库中,最常用的Mysql,数据存储的大小和每秒处理的数据量有关,数据存储取决于每秒处理的数据量和Housekeeper的删除数 ...

  4. iOS类似QQ好友展开和合并列表的实现代码

    其实原理就是好友列表合上的时候,将这组的cell数设置为0,展开的时候,在变成原来的,就是这么简单 -(); }

  5. ios 视频音乐播放

    IOS开发小技巧(视频和音乐播放).IOS视频播放代码(添加MediaPlayer.framework和#import) -(void)playMovie:(NSString *)fileName{ ...

  6. org.apache.catalina.connector.ClientAbortException

    记个tomcat常见流输出中断异常 org.apache.catalina.connector.ClientAbortException: java.net.SocketException: Conn ...

  7. 11_Servlet的一些细节知识点

    [Servlet的细节知识点1-----一个Servlet映射到多个URL] 同一个Servlet可以被映射到多个URL上,即多个<servlet-mapping>元素的<servl ...

  8. Linux用户级线程和内核级线程区别

    1.内核级线程: (1)线程的创建.撤销和切换等,都需要内核直接实现,即内核了解每一个作为可调度实体的线程.(2)这些线程可以在全系统内进行资源的竞争.(3)内核空间内为每一个内核支持线程设置了一个线 ...

  9. Linux 终端中常用的快捷键

    1. 移动光标快捷键 ctrl+f 向前移动一个字符 ctrl+b 向后移动一个字符 alt+f 向前移动一个单词 alt+b 向后移动一个单词 ctrl+a 移动到当前行首 ctrl+e 移动到当前 ...

  10. 实时监听input输入框value值的变化

    1.js 的 oninput & onpropertychange JS中的 oninput 事件在 IE9 以下版本不支持,需要使用 IE 特有的 onpropertychange 事件替代 ...