util 是一个 Node.js 核心模块,提供常用函数的集合,用于弥补核心 Javascript 功能过于精简的不足。
创新互联公司专注于坊子网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供坊子营销型网站建设,坊子网站制作、坊子网页设计、坊子网站官网定制、成都小程序开发服务,打造坊子网络公司原创品牌,更为您提供坊子网站排名全网营销落地服务。
util.inherits(constructor, superConstructor)
实现对象间原型继承的函数,第一个构造函数 将从 第二个构造函数那里继承原型的方法
JavaScript 的面向对象特性是基于原型的,与常见的基于类的不同。JavaScript 没有 提供对象继承的语言级别特性,而是通过原型复制来实现
示例代码如下:
var util = require('util'); //基础对象 function Base(){ this.name = 'base'; this.base = '1990'; this.sayHello = function(){ console.log('Hello '+this.name); } }; Base.prototype.showName = function(){ console.log(this.name); }; //继承自 Base 的对象 function Sub(){ this.name = 'sub'; } util.inherits(Sub, Base); var objBase = new Base(); objBase.showName(); objBase.sayHello(); console.log(objBase); var objSub = new Sub(); objSub.showName(); console.log(objSub);
我们定义了一个基础对象 Base 和一个继承自 Base 的 Sub,Base 有三个在构造函数内定义的属性和一个原型中定义的函数,通过 util.inherits 实现继承。结果如下:
注意,Sub 仅仅继承了 Base 在原型中定义的函数,而构造函数内部创造的 base 属性和 sayHello 函数都没有被 Sub 继承。同时,在原型中定义的属性不会被 console.log 作为对象的属性输出。
尝试打印输出 objSub.sayHello() 这个方法,输出的结果是:
util.inspect(object,[showHidden],[depth],[colors]
是一个将任意对象转换成字符串的方法,通常用于调试和错误输出。
util.inspect 接受至少一个参数 object,即要转换的对象。
其它可选参数如下:
showHidden
<boolean> 是一个可选参数,如果值为 true,将会输出更多隐藏信息
depth
<number> 表示最大递归的层数,如果对象很复杂,你可以指定层数以控制输出信息的多少。如果不指定 depth
,默认会递归 2 层;指定为 null,表示不限制递归层数,完整遍历对象
colors
<boolean> 如果值为 true,输出格式将会以 ANSI 颜色编码,通常用于在终端显示更漂亮的效果
特别要指出的是,util.inspect 并不会简单地直接把对象转换为字符串,即使该对 象定义了 toString 方法也不会调用
示例代码如下:
var util = require('util'); function Person(){ this.name = 'Roger'; this.toString = function(){ return this.name; } } var obj = new Person(); console.log(util.inspect(obj)); console.log(util.inspect(obj, true));
运行结果:
网站题目:Node.js常用工具util
转载来于:https://www.cdcxhl.com/article36/pohpsg.html
成都网站建设公司_创新互联,为您提供域名注册、品牌网站制作、企业网站制作、响应式网站、移动网站建设、外贸网站建设
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联