NodeJS学习笔记 (27)实用工具模块-util(ok)
debuglog(section)
很有用的调试方法。可以通过 util.debuglog(name) 来创建一个调试fn,这个fn的特点是,只有在运行程序时候,声明环境变量NODE_DEBUG=name,才会打印出调试信息。
可以看下面的例子,直接运行 node debuglog.js
,没有任何输出。需要NODE_DEBUG=foo
,才会有打印信息.
var util = require('util');
var logger = util.debuglog('foo'); logger('hello');
如下所示,注意,6347 是当前进程id。
➜ 2016.12.02-util git:(master) ✗ NODE_DEBUG=foo node debuglog.js
FOO 6347: hello world
此外,还可以一次指定多个name
,通过逗号分隔。
var util = require('util');
var firstLogger = util.debuglog('first');
var secondLogger = util.debuglog('second');
var thirdLogger = util.debuglog('third'); firstLogger('hello');
secondLogger('hello');
thirdLogger('hello');
运行如下:
FOO 6347: hello world
➜ 2016.12.02-util git:(master) ✗ NODE_DEBUG=first,second node debuglog.js
FIRST 6456: hello
SECOND 6456: hello
将方法标识为作废:util.deprecate(fn, str)
将fn
包裹一层,并返回一个新的函数fn2
。调用fn2
时,同样完成fn
原有的功能,但同时会打印出错误日志,提示方法已作废,具体的提示信息就是第二个参数str
。
var util = require('util');
var foo = function(){
console.log('foo');
}; var foo2 = util.deprecate(foo, 'foo is deprecate'); foo2(); // 输出如下:
// foo
// (node:6608) DeprecationWarning: foo is deprecate
如果嫌错误提示信息烦人,可以通过--no-deprecation
参数禁掉,可以参考这里。
➜ 2016.12.02-util git:(master) ✗ node --no-deprecation deprecate.js
foo
格式化打印:util.format(format[, ...args])
格式化打印大家应该比较熟悉了,基本每种语言里都有自己的实现,直接上例子。
var util = require('util'); console.log( util.format('hello %s', 'world') );
// 输出:hello world console.log( util.format('1 + 1 = %d', 2) );
// 输出:1 + 1 = 2 console.log( util.format('info: %j', {nick: 'chyingp'}) );
// 输出:info: {"nick":"chyingp"} console.log( util.format('%s is %d age old', 'chyingp') );
// 输出:chyingp is %d age old console.log( util.format('%s is a man', 'chyingp', 'indeed') );
// 输出:chyingp is a man indeed
调试方法:util.inspect(obj[, options])
非常实用的一个方法,参数说明如下:
- obj:js原始值,或者对象。
- options:配置参数,包含下面选项
- showHidden:如果是true的话,obj的非枚举属性也会被展示出来。默认是false。
- depth:如果obj是对象,那么,depth限制对象递归展示的层级,这对可读性有一定的好处,默认是2。如果设置为null,则不做限制。
- colors:自定义配色方案。
- showProxy:
- maxArrayLength:如果obj是数组,那么限制最大可展示的数组个数。默认是100,如果设置为null,则不做限制。如果设置为0或负数,则一个都不展示。
var util = require('util'); var obj = {}; Object.defineProperty(obj, 'nick', {
enumerable: false,
value: 'chyingp'
}); console.log( util.inspect(obj) );
// 输出:{} console.log( util.inspect(obj, {showHidden: true}) );
// 输出:{ [nick]: 'chyingp' }
NodeJS学习笔记 (27)实用工具模块-util(ok)的更多相关文章
- NodeJS学习笔记之Connect中间件模块(一)
NodeJS学习笔记之Connect中间件模块(一) http://www.jb51.net/article/60430.htm NodeJS学习笔记之Connect中间件模块(二) http://w ...
- Nodejs学习笔记(三)--- 模块
目录 简介及资料 自定义模块 创建一个自定义模块 调用自定义模块 exports和module.exports 区别 exports和module.exports 覆盖 其它... 简介及资料 通过N ...
- Nodejs学习笔记(三)—模块
简介及资料 通过Node.js的官方API可以看到Node.js本身提供了很多核心模块 http://nodejs.org/api/ ,这些核心模块被编译成二进制文件,可以require('模块名') ...
- 【转】Nodejs学习笔记(二)--- 模块
目录 简介及资料 自定义模块 创建一个自定义模块 调用自定义模块 exports和module.exports 区别 exports和module.exports 覆盖 其它... 简介及资料 通过N ...
- nodejs学习笔记之包、模块实现
简单了解了node的安装和一些基本的常识之后,今天学习了node中很重要的包和模块的一些知识点. 首先学习一下包的规范,它由包结构和包描述两部分组成.包结构用于组织包的各种文件,包 ...
- NodeJS学习笔记之Connect中间件模块(二)
一,开篇分析 大家好,今天这篇文章主要是对"Connect"中间件以及相关辅助中间件,做一个源码分析系列,我想上一篇文章大家也看了, 介绍了使用方式及用途,而这篇也是出于本人的兴趣 ...
- NodeJS学习笔记 进阶 (12)Nodejs进阶:crypto模块之理论篇
个人总结:读完这篇文章需要30分钟,这篇文章讲解了使用Node处理加密算法的基础. 摘选自网络 Nodejs进阶:crypto模块之理论篇 一. 文章概述 互联网时代,网络上的数据量每天都在以惊人的速 ...
- Nodejs学习笔记(三)——一张图看懂Nodejs建站
前言:一条线,竖着放,如果做不到精进至深,那就旋转90°,至少也图个幅度宽广. 通俗解释上面的胡言乱语:还没学会爬,就学起走了?! 继上篇<Nodejs学习笔记(二)——Eclipse中运行调试 ...
- Nodejs学习笔记(十六)--- Pomelo介绍&入门
目录 前言&介绍 安装Pomelo 创建项目并启动 创建项目 项目结构说明 启动 测试连接 聊天服务器 新建gate和chat服务器 配置master.json 配置servers.json ...
随机推荐
- ubuntu12.04下CKermit与开发板交互环境搭建
CKermit蛮好的一个调试工具!就像在windows下的telnet,但是还是折腾了一下,现在看来,非常容易,其实我主要是在开发板为正常工作的情况下,以为是CKermit的问题,其实是我开发板开机设 ...
- 移动端video播放时不弹出页面层
移动端视频在播放时会主动弹出页面,有的浏览器不会.对那些会的浏览器进行处理: 直接加上下面三个属性即可,兼容方面就不说了,微信上是很ok的. <video x5-playsinline=&quo ...
- 在Jquery里格式化Date日期时间数据
在Jquery里格式化Date日期时间数据: $(function(){ //当前时间格式化yyyy-MM-dd HH:mm:ss alert(timeStamp2String(new Date(). ...
- X86 X64 X86_64 AMD64 区别
X86:32位(一般i386是32位CPU的统称) X64:64位(代表CPU:IA64,现在几乎没有这样纯粹的64位CPU,都是兼容32位的64位CPU,如下) X86_64:兼容32位的64位CP ...
- Servlet学习(一)——Servlet的生命周期、执行过程、配置
1.什么是Servlet Servlet 运行在服务端的Java小程序,是sun公司提供一套规范(接口),用来处理客户端请求.响应给浏览器的动态资源.但servlet的实质就是java代码,通过jav ...
- yaml文件结构
VERSION: 1.0.0.1 --指定控制文件schema的版本DATABASE: db_name --指定连接数据库的名字,如果没有指定,由环境变量$P ...
- MySQL用户添加和分配权限
mysql数据库insertdelete服务器file mysql> grant 权限1,权限2,…权限n on 数据库名称.表名称 to 用户名@用户地址 identified by ‘连接口 ...
- python下载网页转化成pdf
最近在学习一个网站补充一下cg基础.但是前几天网站突然访问不了了,同学推荐了waybackmachine这个网站,它定期的对网络上的页面进行缓存,但是好多图片刷不出来,很憋屈.于是网站恢复访问后决定把 ...
- Hadoop-2.4.1 ubuntu集群安装配置教程
一.环境 系统: Ubuntu 14.04 32bit Hadoop版本: Hadoop 2.4.1 (stable) JDK版本: 1.7 集群数量:3台 注意事项:我们从Apache官方网站下载的 ...
- SpaceVim配置中遇到的问题
这是一个不断更新的随笔,若遇到SpaceVim配置问题时,会添加项 字体乱码(linux企鹅乱码,tabline图标乱码等) git clone https://github.com/powerlin ...