Node中的全局对象和全局变量

这个文章主要是对上一个文章的扩充

util对象

在Node环境已经安装好的前提下,使用util中已经定义的方法,只需要require(‘util‘)即可;

uti是utility(功效,用途)的缩写。这util模块的设计主要是为了满足Node内部API的需求。下面来介绍两个比较重要的:

1.inherits

这个方法实现了原型链之间的继承(即JavaScript的继承)

var util = require(‘util‘);
function base(){
    this.name = ‘helios‘;
    this.sayName=function(){
        console.log(this.name);
    }
}
base.prototype.sayHello=function(){
    console.log(‘hello ‘+this.name);
};
function sub(){
    this.name=‘shangyilong‘;
    this.age = 21;
}
//通过util对象下面的inherits这个方法实现了sub继承base
util.inherits(sub,base);

var a =  new sub();
a.sayHello();

2.inspect(util.inspect(object[, options]))

这个方法是将任意的对象转换为字符串格式的,一般是用在调试。

- 第一个参数是必选的,一个任意对象

- 除了第一个后面都是可选的参数,第二个参数[showHidden]默认的情况下是false,当设置为true的时候可以打印出这个对象不可枚举属性标志属性

- 第三个参数depth表示打印出这个对象的多少层属性,这个方法对待结构复杂的对象十分有效,默认的情况下是打印两层,如果想要无限的递归打印出所有的属性可以设置为null;

- 颜色colors 默认的情况下是false表示所有额属性都是一种颜色,如果设置为true的话就是按照代码的ANSI打印出代码的

下面来看一下代码:

var util = require(‘util‘);
function base(){
    this.name = ‘helios‘;
    this.sayName=function(){
        console.log(this.name);
    }
    this.toString=function () {
        console.log("hello");
    }
}

var a =  new base();

console.log(util.inspect(util, { showHidden: true, depth: null ,colors: true , customInspect:false}));
//下面这一行代码是等于上面的
//console.log(util.inspect(a,true,null,true,false));
- 3.在控制台输出
```javascript
util.log("shagnyilong");
// output 9 May 19:03:05 - shangyilong

<div class="se-preview-section-delimiter"></div>

除了以上的还能检查是否是字符串是否符合正则,都是差不多的形式可以参考官方文档,在这里就不进行赘述:

util模块官网文档

events模块

在Node中所有的异步I/O操作都是使用事件机制来实现的,Node中很多对象都是events.EventEmitter的实例。例如在fs模块中打开和读取文件都是分对应的事件的,Node通过events实现事件机制,该模块中有唯一的类:EventEmitter.

EventEmitter的核心就是事件发射与事件监听器功能的封装.对于每个事件,EventEmitter支持若干个事件监听器。当事件发射时,注册到这个事件的事件监听器被依次调用,事件参数作为回调函数参数传递。

常用API的方法介绍:

(1)EventEmitter.on(event,listener)为指定事件注册一个监听器,接受一个字符串event和一个回调函数listener

(2)EventEmitter.emit(event,[arg1],[arg2]….) 发射event事件,传递若干可选参数到事件监听器的参数表

(3)EventEmitter.once(event,listener) 为指定事件注册一个单次监听器,即监听器最多只会触发一次,触发后立刻解除该监听器。

(4)EventEmitter.removeListener(event,listener)移除指定事件的某个监听器,listener必须是该事件已经注册过的监听器。

(5)EventEmitter.removeAllListeners([event]) 移除所有事件的所有监听器,如果指定event,则移除指定事件的所有监听器。

下面看一个案例:

“`

除了以上的还能检查是否是字符串是否符合正则,都是差不多的形式可以参考官方文档,在这里就不进行赘述:
[util模块官网文档](https://nodejs.org/api/util.html)

##  events模块
在Node中所有的异步I/O操作都是使用事件机制来实现的,Node中很多对象都是`events.EventEmitter`的实例。例如在fs模块中打开和读取文件都是分对应的事件的,Node通过events实现事件机制,该模块中有唯一的类:`EventEmitter`.
EventEmitter的核心就是事件发射与事件监听器功能的封装.对于每个事件,EventEmitter支持若干个事件监听器。当事件发射时,注册到这个事件的事件监听器被依次调用,事件参数作为回调函数参数传递。
  常用API的方法介绍:
               (1)EventEmitter.on(event,listener)为指定事件注册一个监听器,接受一个字符串event和一个回调函数listener
               (2)EventEmitter.emit(event,[arg1],[arg2]....) 发射event事件,传递若干可选参数到事件监听器的参数表
               (3)EventEmitter.once(event,listener) 为指定事件注册一个单次监听器,即监听器最多只会触发一次,触发后立刻解除该监听器。
               (4)EventEmitter.removeListener(event,listener)移除指定事件的某个监听器,listener必须是该事件已经注册过的监听器。
               (5)EventEmitter.removeAllListeners([event]) 移除所有事件的所有监听器,如果指定event,则移除指定事件的所有监听器。
下面看一个案例:
```javascript
var events=require(‘events‘);
var emitter=new events.EventEmitter();
emitter.on(‘someEvent‘,function(arg1,arg2){
    console.log(‘Listener1‘,arg1,arg2);
});
emitter.on(‘someEvent‘,function(arg1,arg2){
    console.log(‘Listener2‘,arg1,arg2);
});
//下面是给一个给someEvent绑定了多个事件
emitter.emit(‘someEvent‘,‘marico‘,1991);

<div class="se-preview-section-delimiter"></div>

关于events的继承

大多数时候我们不会直接使用 EventEmitter,而是在对象中继承它。包括 fs、net、 http 在内的,只要是支持事件响应的核心模块都是 EventEmitter 的子类。

为什么要这样做呢?原因有两点:

首先,具有某个实体功能的对象实现事件符合语义, 事件的监听和发射应该是一个对象的方法。

其次 JavaScript 的对象机制是基于原型的,支持 部分多重继承,继承 EventEmitter 不会打乱对象原有的继承关系。

下面来看一个具体的例子:

“`

### 关于events的继承
大多数时候我们不会直接使用 EventEmitter,而是在对象中继承它。包括 fs、net、 http 在内的,只要是支持事件响应的核心模块都是 EventEmitter 的子类。
为什么要这样做呢?原因有两点:
首先,具有某个实体功能的对象实现事件符合语义, 事件的监听和发射应该是一个对象的方法。
其次 JavaScript 的对象机制是基于原型的,支持 部分多重继承,继承 EventEmitter 不会打乱对象原有的继承关系。
下面来看一个具体的例子:
```javascript
const util = require(‘util‘);
var events=require(‘events‘);
var emitter=new events.EventEmitter();

function MyEventEmitter() {
    // 初始化`events`this实例上必要的属性
    events.call(this);
}

// 继承`EventEmitter`原型链上的方法
util.inherits(MyEventEmitter, events);
//实例化一个MyEventEmitter
var a = new MyEventEmitter();
//表示已经继承成功了
a.on(‘amo‘,function(){
    console.log(8);
});

这是Node的一个系列,可以在本栏目下看其他关于Node文章,会 一直更新,有问题请在下方留言

时间: 2024-10-01 05:29:05

Node中的全局对象和全局变量的相关文章

Node.js的全局对象和全局变量

1.全局对象 所有模块都可以调用 1)global:表示Node所在的全局环境,类似于浏览器中的window对象. 2)process:指向Node内置的process模块,允许开发者与当前进程互动. 例如你在DOS或终端窗口直接输入node,就会进入NODE的命令行方式(REPL环境).退出要退出的话,可以输入 process.exit(); 3)console:指向Node内置的console模块,提供命令行环境中的标准输入.标准输出功能. 通常是写console.log(),无须多言 2.

Node中的全局对象

global global顶级对象,类似于浏览器中的window 在任何地方可以直接使用,不需要导包 setTimeout/setImmediate/process.nextTick,异步的时候setTimeout的优先级高于setImmediate,process.nextTick优先级最高 setInterval 在REPL环境中定义的变量直接挂载到global中 在js文件中定义的变量不会挂载到global中 获取路径 __dirname 当前执行的js所在的文件夹 __filename

Node.js:全局对象

概要:本篇博客主要介绍了node.js中的全局对象. 在JavaScript中,通常window是全局对象,而node.js中的全局对象是global,所有全局变量(除了global本身之外)都是global对象的属性.如:console.process. 1.全局对象与全局变量 global最根本的作用是作为全局变量的宿主.满足以下条件: ●在最外层定义的变量: ● 全局对象的属性: ● 隐式定义的变量(未定义直接赋值的变量). 2.process process是一个全局变量,即global

nodejs学习笔记 -- 全局对象与全局变量

全局对象 在浏览器Javascript中,window是全局对象,而Node.js中全局对象是global,所有全局变量(除了global本身以外)都是global对象的属性. 在Node.js中,我们可以直接访问到global的属性,而不需要在应用中包含它. 全局变量 global 最根本的作用是作为全局变量的宿主.按照 ECMAScript 的定义,满足以下条 件的变量是全局变量: 1.在最外层定义的变量: 2.全局对象的属性: 3.隐式定义的变量(未定义直接赋值的变量). 定义一个全局变量

node 中的global对象和process对象

因为Node.js是运行在服务区端的JavaScript环境,服务器程序和浏览器程序相比,最大的特点是没有浏览器的安全限制了,而且,服务器程序必须能接收网络请求,读写文件,处理二进制内容,所以,Node.js内置的常用模块就是为了实现基本的服务器功能.这些模块在浏览器环境中是无法被执行的,因为它们的底层代码是用C/C++在Node.js运行环境中实现的. global 在前面的JavaScript课程中,我们已经知道,JavaScript有且仅有一个全局对象,在浏览器中,叫window对象.而在

读书笔记-JavaScript中的全局对象

对于任何JavaScript程序,当程序开始运行时,JavaScript解释器都会初始化一个全局对象以供程序使用.这个JavaScript自身提供的全局对象的功能包括: 1.全局对象拥有一些常用的属性值.比如undefined.Infinity以及NaN.2.全局对象拥有一些常用的属性对象.比如Math.JSON和Number对象均为该全局对象的属性.3.全局对象提供一些全局函数供调用.比如isNaN().isFinite().parseInt()和eval()等.4.全局对象提供一些全局构造器

Python中通过函数对象创建全局变量

先看下面这段代码,显然无法work. 因为代码试图在TestVariableScope()中引用一个没有被定义的变量a.所以必须报错,如下图-1. 不过如果你将第2行代码注释掉.代码就能跑通了,如图-2. 问题1来了:TestVariableScope.a 不是也没有被定义吗,为什么可以work呢?解释如下:先看代码第8行,TestVariableScope.a在SetVariable方法中被定义了,SetVariable()又 在TestVariableScope()前被调用.所以TestVa

[百度空间] [转] 在 Visual C++ 中控制全局对象的初始化顺序

from: http://blog.csdn.net/classfactory/archive/2004/08/07/68202.aspx 在 C++ 中,同一个翻译单位(.cpp文件)里的全局对象的初始化顺序是先定义的对象先初始化(同时也后析构),但 C++ 标准并没有规定不同翻译单位间全局对象的初始化顺序.按照这个分析,以下的代码可能工作,也可能不工作(cout 是 C++ 用于输出的全局对象,和我们自己的对象位于不同的翻译单位): class A {    A() {        cou

nodejs 全局对象

1. 全局对象console的五个方法: log   dir    time  timeEnd  error 2. 在前端中全局对象Window中定义了consle这个对象 3. 在nodejs中全局对象是global,在global中定义了console. 4. setInterval也是global中定义的全局对象 5. setTimeout也是global中定义的全局对象 6. __dirname 也是全局对象,表示当前文件所在的路径 7. __filename也是全局对象,表示当前文件所