Node.js中process模块常用的属性和方法


Posted in Javascript onDecember 13, 2016

前言

虽然node对操作系统做了很多抽象的工作,但是你还是可以直接和他交互,比如和系统中已经存在的进程进行交互,创建工作子进程。node是一个用于事件循环的线程,但是你可以在这个事件循环之外创建其他的进程(线程)参与工作。

如果不是和命令行工具打交道,可能我们很少有机会去用到process模块中的一些方法或者属性。不过如果你要做类似于webpack或者gulp等较为复杂的构建工具,由于bash界面就是和用户直接交流的工具,因此友好的输入输出,完整的提示都非常有必要了。

属性

一张表格大概可以看到process有哪些属性

属性名称 用途
platform 判断当前系统平台
argv 当前进程的命令行参数数组
execPath 当前进程的可执行文件的绝对路径
stdout 指向标准输出
stdin 指向标准输入
stderr 指向标准错误
stderr 指向标准错误

我们可以直接在代码中这样使用

console.log(porcess.platform) 
// darwin

使用argv 会返回命令行的数组,我们可以通过数组来获取用户具体的命令

console.log(process.argv); 
// [ '/usr/local/bin/node', '/Users/ali-130257n/www/weex-jackzoo/projects/demo.js', '-p', '-v' ]

一般情况下,我们更想获取最后的一些参数,前面两个不需要,我们可以

let args = process.argv.slice(2); 
console.log(args)

// [ '-p', '-v' ]

方法

process 提供的方法有很多。大致我们可以用到的有下面一些。

     cwd:返回运行当前脚本的工作目录的路径

     abort:立即结束进程

     nextTick: 指定下次事件循环首先运行的任务

process 支持的一些事件,通过一些事件,我们可做一些友好的提示或者处理。

     uncaughtException:当前进程抛出一个没有被捕捉的意外时,会触发uncaughtException事件

     message: 接受来自父进程的消息

     rejectionHandled:用于捕获与它关联的promise错误处理并且产生的reject

     unhandledRejection: 同理这个便是用于捕获没有与之关联promise错误处理的reject

const unhandledRejections = new Map(); 
process.on('unhandledRejection', (reason, p) => { 
 unhandledRejections.set(p, reason);
});
process.on('rejectionHandled', (p) => { 
 unhandledRejections.delete(p);
});

warning: 当前进程产生一个警告的时候出发

process.on('warning', (warning) => { 
 console.warn(warning.name); // Print the warning name
 console.warn(warning.message); // Print the warning message
 console.warn(warning.stack); // Print the stack trace
});

总结

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

Javascript 相关文章推荐
兼容多浏览器的iframe自适应高度(ie8 、谷歌浏览器4.0和 firefox3.5.3)
Nov 04 Javascript
JavaScript之Getters和Setters 平台支持等详细介绍
Dec 07 Javascript
jQuery弹出层插件Lightbox_me使用指南
Apr 21 Javascript
js库Modernizr的介绍和使用
May 07 Javascript
微信小程序 Tab页切换更新数据
Jan 05 Javascript
JavaScript中的编码和解码函数
Feb 15 Javascript
angularjs数组判断是否含有某个元素的实例
Feb 27 Javascript
JS 实现缓存算法的示例(FIFO/LRU)
Mar 20 Javascript
Vue2实时监听表单变化的示例讲解
Aug 30 Javascript
JS 实现获取验证码 倒计时功能
Oct 29 Javascript
Vue项目部署的实现(阿里云+Nginx代理+PM2)
Mar 26 Javascript
使用watch在微信小程序中实现全局状态共享
Jun 03 Javascript
Angular ng-repeat遍历渲染完页面后执行其他操作详细介绍
Dec 13 #Javascript
node.js 和HTML5开发本地桌面应用程序
Dec 13 #Javascript
AngularJS中$apply方法和$watch方法用法总结
Dec 13 #Javascript
vue.js学习之递归组件
Dec 13 #Javascript
AngularJS过滤器filter用法总结
Dec 13 #Javascript
ES6通过babel转码使用webpack使用import关键字
Dec 13 #Javascript
AngularJS服务service用法总结
Dec 13 #Javascript
You might like
php中检查文件或目录是否存在的代码小结
2012/10/22 PHP
从PHP $_SERVER相关参数判断是否支持Rewrite模块
2013/09/26 PHP
php中fgetcsv()函数用法实例
2014/11/28 PHP
php中的动态调用实例分析
2015/01/07 PHP
利用XMLHTTP传递参数在另一页面执行并刷新本页
2006/10/26 Javascript
setTimeout 不断吐食CPU的问题分析
2009/04/01 Javascript
javascript中String类的subString()方法和slice()方法
2011/05/24 Javascript
JqGrid web打印实现代码
2011/05/31 Javascript
24款热门实用的jQuery插件推荐
2014/12/24 Javascript
JavaScript验证Email(3种方法)
2015/09/21 Javascript
网页前端登录js按Enter回车键实现登陆的两种方法
2016/05/10 Javascript
JavaScript String 对象常用方法详解
2016/05/13 Javascript
javascript中使用未定义变量或值的情况分析
2016/07/19 Javascript
JS实现根据文件字节数返回文件大小的方法
2016/08/02 Javascript
vue.js 1.x与2.0中js实时监听input值的变化
2017/03/15 Javascript
利用Mongoose让JSON数据直接插入或更新到MongoDB
2017/05/03 Javascript
js学使用setTimeout实现轮循动画
2017/07/17 Javascript
jQuery DOM节点的遍历方法小结
2017/08/15 jQuery
vue-cli 组件的导入与使用教程详解
2018/04/11 Javascript
详解VUE自定义组件中用.sync修饰符与v-model的区别
2018/06/26 Javascript
如何解决js函数防抖、节流出现的问题
2019/06/17 Javascript
Element-ui DatePicker显示周数的方法示例
2019/07/19 Javascript
VUE使用 wx-open-launch-app 组件开发微信打开APP功能
2020/08/11 Javascript
Python实现设置windows桌面壁纸代码分享
2015/03/28 Python
python爬取拉勾网职位数据的方法
2018/01/24 Python
详解python中的装饰器
2018/07/10 Python
jupyter notebook 写代码自动补全的实现
2020/11/02 Python
一款基于css3的列表toggle特效实例教程
2015/01/04 HTML / CSS
施工安全协议书
2013/12/11 职场文书
农村党支部书记党群众路线四风问题整改措施
2014/09/26 职场文书
让世界充满爱观后感
2015/06/10 职场文书
【超详细】八大排序算法的各项比较以及各自特点
2021/03/31 Python
5行Python代码实现一键批量扣图
2021/06/29 Python
Maven学习----Maven安装与环境变量配置教程
2021/06/29 Java/Android
分布式Redis Cluster集群搭建与Redis基本用法
2022/02/24 Redis
Python时间操作之pytz模块使用详解
2022/06/14 Python