Node笔记三
global
--类似与客户端javascript运行环境中的window
process
--用于获取当前node进程信息,一般用于获取环境变量之类的信息
console
--node中内置的console模块,提供操作控制台的输入输出功能,常见是用方式与客户端类似

node中只有这三个是真正的全局对象,其他的一些全局对象都是模块内的伪全局对象


在查看api时,会看到如此提示,node会将方法的稳定性分为三个级别0、1、2,0代表稳定性最低,2代表稳定性最高。
--由于一些api已经被淘汰,但是需要适应老版本,因此将这些api保留,直到使用率很低的时候才将此api进行删除。符合软件迭代规律。
--目前4版本为长期维护版本,里面的api基本稳定、不会删,市场主流是使用4版本开发系统
process模块
--process.arch 查询操作系统类型
--process.argv
--var argv = process.argv; console.log(argv);
--在控制台输出
'C:\\dev\\nodejs\\node.exe' 代表node.exe所在的目录
'D:\\MyDrivers\\workSpace\\node\\demo1'代表执行文件所在的目录
--当我们在REPL环境中输入指令时,eg: npm init, npm内部会对输入的指令做出判断,npm 是方法, init是参数,当参数是init时进行初始化操作, npm install jquery 则进行安装包。
npm内部对指令做出对应的处理:
如图所示,在控制台 输入 npm 执行文件 参数1 参数2 ... ,npm就会根据对应的参数执行操作。
Node调试
--最简单、方便调试方式 : console.log();
--使用debug调试,直接在控制台书写 node debug 执行文件名 便可以进入调试。
--进入调试阶段,输入help可以 查看在cmd中的指令进行调试。
--使用工具进行调试,使用Visual studio Code工具进行调试。
--在进行调试之前,需要需要json文件program中的app.js,将其修改为将要进行调试的文件名即可。${workspaceRoot}代表当前执行目录根目录。

--第三方模块提供的调试工具,需要npm download
--$npm install node-inspector -g
--$npm install devtool -g
简单的登录逻辑
// 输出第一个问题
process.stdout.write('请输入用户名:\n');
// var i = 0;
var isInputUsername = true;
var username = '';
// 接收用户输入
process.stdin.on('data', (input) => {
// console.log(i++);
// 要在此处知道到底input是啥?
input = input.toString().trim();
if (!username) {
if (Object.keys(users).indexOf(input) === -1) {
process.stdout.write('用户名不存在' + '\n');
process.stdout.write('请输入用户名:\n');
// isInputUsername = true;
username = '';
} else {
// console.log('存在');
process.stdout.write('请输入密码:\n');
// isInputUsername = false;
username = input;
}
} else {
// 传入的是密码,此处拿不到上次的输入,所以拿不到用户名
// console.log(11111);
if (input === users[username]) {
console.log('登陆成功');
}else{
process.stdout.write('请输入密码:\n');
}
}
});
Node笔记三的更多相关文章
- ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心
作者:Grey 原文地址:ZooKeeper学习笔记三:使用ZooKeeper实现一个简单的配置中心 前置知识 完成ZooKeeper集群搭建以及熟悉ZooKeeperAPI基本使用 需求 很多程序往 ...
- Oracle学习笔记三 SQL命令
SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)
- 《CMake实践》笔记三:构建静态库(.a) 与 动态库(.so) 及 如何使用外部共享库和头文件
<CMake实践>笔记一:PROJECT/MESSAGE/ADD_EXECUTABLE <CMake实践>笔记二:INSTALL/CMAKE_INSTALL_PREFIX &l ...
- Mastering Web Application Development with AngularJS 读书笔记(三)
第一章笔记 (三) 一.Factories factory 方法是创建对象的另一种方式,与service相比更灵活,因为可以注册可任何任意对象创造功能.例如: myMod.factory('notif ...
- Python 学习笔记三
笔记三:函数 笔记二已取消置顶链接地址:http://www.cnblogs.com/dzzy/p/5289186.html 函数的作用: 給代码段命名,就像变量給数字命名一样 可以接收参数,像arg ...
- 《MFC游戏开发》笔记三 游戏贴图与透明特效的实现
本系列文章由七十一雾央编写,转载请注明出处. 313239 作者:七十一雾央 新浪微博:http://weibo.com/1689160943/profile?rightmod=1&wvr=5 ...
- [Firefly引擎][学习笔记三][已完结]所需模块封装
原地址:http://www.9miao.com/question-15-54671.html 学习笔记一传送门学习笔记二传送门 学习笔记三导读: 笔记三主要就是各个模块的封装了,这里贴 ...
- JSP学习笔记(三):简单的Tomcat Web服务器
注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...
- 构建高性能WEB站点笔记三
构建高性能WEB站点笔记三 第10章 分布式缓存 10.1数据库的前端缓存区 文件系统内核缓冲区,位于物理内存的内核地址空间,除了使用O_DIRECT标记打开的文件以外,所有对磁盘文件的读写操作都要经 ...
随机推荐
- SpringMVC返回json是设置编辑等消息头,消息头信息介绍(respone.setHeader,这个从网上获取)
1. SpringMVC中设置消息头,例子如下: ? 因为上面的代码没有添加该文件的编码说明 , WEB应用程序在将jsp翻译成class文件时 , 把该字符串的内容按默认的保存方式指定的编码ASC ...
- C#之DirectoryInfo操作
在C#中的System.IO命名空间下有大量的库供我们使用,下面一起来看一下DirectoryInfo的使用吧. code: using System; using System.Collection ...
- Linux多线程实践(4) --线程特定数据
线程特定数据 int pthread_key_create(pthread_key_t *key, void (*destr_function) (void *)); int pthread_key_ ...
- mongoDB介绍、安装、搭建简单的mongoDB服务器(一)
相关网站 1. http://www.mongodb.org/ 官网,可以下载安装程序,和doc,和驱动等. 2. http://www.mongoing.com/ 国内官方网站,博客,问题谈论等 ...
- 看看腾讯是怎么做产品设计分析的 - 腾讯QQ音乐业务产品规划
- 【翻译】Ext JS最新技巧——2014-8-13
原文:Top Support Tips Greg Barry:新的框架. 新的文档类型(Doctype) 在Ext JS 5,只支持IE8+,因此不再古力用户使用严格的HTML文档类型.现在,推荐使用 ...
- Material Design之CardView的使用
本文介绍CardView这个控件的使用,CardView继承至FrameLayout类,是support-v7包下的一个类,使用时必须引入cardview依赖包,可在下载的sdk文件夹中找到... 使 ...
- 【翻译】为Ext JS和Sencha Touch开发人员准备的应用程序监测(App Inspector)
和其他的Sencha开发人员一样,我会花费大约半天的时间在我喜欢的IDE工具上编写JavaScript,而另一半时间则是在浏览器上测试和调试我的应用程序.在过去几年,每一个主要的浏览器都已大为改善.现 ...
- 基于ARM_contexA9 led驱动编程
关于友善之臂出的这款contexA9开发板,目前在网络上的资源较少,特别是内核的,非常之少,鉴于这种情况,我将会写一个系列的驱动来做关于tiny4412这款板子开发的总结. 简单介绍一下: Tiny4 ...
- AngularJS进阶(十八)在AngularJS应用中集成科大讯飞语音输入功能
在AngularJS应用中集成科大讯飞语音输入功能 注:请点击此处进行充电! 前言 根据项目需求,需要在首页搜索框中添加语音输入功能,考虑到科大讯飞语音业务的强大能力,遂决定使用科大讯飞语音输入第三方 ...