Node入门教程(5)第四章:global 全局变量

global - 全局变量

全局对象(global object),不要和 全局的对象( global objects )或称标准内置对象混淆。这里说的全局的对象是说在全局作用域里的内的对象。全局作用域包含了全局对象的属性,还有它继承来的属性。

注意浏览器下的全局对象跟 nodejs 中的全局对象不一致

  • 浏览器环境下的全局对象就是window
  • Node 的全局对象是 global

JS 语言标准的全局的内置对象

JS 语言规范中的全局的内置对象在 Nodejs 中都有效,以下简单过一下,不熟悉请查MDN 文档

  • 全局属性
    • Infinity
    • NaN
    • undefined
    • null 字面量
  • 函数属性
    • eval()
    • uneval()
    • isFinite()
    • isNaN()
    • parseFloat()
    • parseInt()
    • decodeURI()
    • decodeURIComponent()
    • encodeURI()
    • encodeURIComponent()
    • escape()
    • unescape()
  • 基本对象与其他内容
    • Object
    • Function
    • Boolean
    • Symbol
    • Error
    • Number
    • Math
    • Date
    • String
    • RegExp
    • Array
    • Map
    • Set
    • JSON
    • ArrayBuffer
    • Promise
    • Generator
    • GeneratorFunction
    • Reflect
    • Proxy
    • arguments

nodejs 中的全局变量

关于模块的补充

这里先简单补充一下模块的概念,后续我们还会更深入讲解一下,笔者不想让复杂的内容让初学者分心,只是想让您能快速先建立学习 Nodejs 的信心。NodeJs 中把不同功能的 api 封装成不同的模块,避免了不同功能的代码相互冲突。当然 NodeJS 也支持开发人员写的 Nodejs 代码模块化。如果你是 Java、DotNet 的程序员,那 Nodejs 的模块就是 DotNet 的程序集或者 Java 的包。

Node 中所有的代码都会被 node 编译器自动包装成模块后再进行解析执行,具体细节后面会有详解。

console(控制台)

console 模块提供了一个简单的调试控制台,类似于 Web 浏览器提供的 JavaScript 控制台。

注意:全局的 console 对象的方法既不总是同步的(如浏览器中类似的 API)

全局的console对象可以再 node 中任何地方直接调用。接下来看看它的常用方法。

  1. 打印日志 console.log

语法:console.log([data][, ...args])

打印到输出控制台,并带上换行符。 可以传入多个参数,第一个参数作为主要信息(字符串类型),其他参数作为代替值。

var count = 5;
console.log('count: %d', count);
// 打印: count: 5 到 stdout
console.log('count:', count);
// 打印: count: 5 到 stdout
console.log('count:', count, '-222', '-999');
// 打印: count:5-222-999。  log方法可以把多个参数连接一块输出。

log 方法的第一个参数是一个字符串,包含零个或多个占位符。 每个占位符会被对应参数转换后的值所替换。 支持的占位符有

%s - 字符串。
%d - 数值(整数或浮点数)。
%i - Integer.
%f - Floating point value.
%j - JSON。如果参数包含循环引用,则用字符串 '[Circular]' 替换。
...

更多请参考:Node 文档

console.info() 函数是 console.log() 的一个别名。也就是说你用log方法跟info方法一致。

  1. 打印错误消息和警告信息

语法:console.error([data][, ...args])

error方法的使用同 log方法,所以不赘述,我们一般用此方法打印错误消息,一般用log方法打印普通消息。

console.error('error');

另外打印警告信息使用warn方法,此方法仅仅提示开发人员一些警示信息,用法同log方法。

语法:console.warn([data][, ...args])

  1. 打印对象结构

语法: console.dir(obj[, options])

参数说明:

  • 第一个参数obj,就是要打印属性的对象。

  • 第二个参数options是设置打印的配置项:

    • showHidden - 如果为 true,则该对象中的不可枚举属性和 symbol 属性也会显示。默认为 false。

    • depth - 告诉 util.inspect() 函数当格式化对象时要递归多少次。 这对于检查较大的复杂对象很有用。 默认为 2。 设为 null 可无限递归。

    • colors - 如果为 true,则输出会带有 ANSI 颜色代码。 默认为 false。 颜色是可定制的,详见定制 util.inspect() 颜色。

var a = { age: 134, t: { name: '33', mm: '333' } };
console.dir(a);
console.dir(a, {
  colors: true,
  showHidden: true
});

dir方法非常有用,在可以辅助我们调试时查看对象内的属性和继承关系,也是一个非常好的学习js的手段。

  1. 时间计时

同浏览器一致,也封装了计时的两个方法:console.time(label)console.timeEnd(label);

time方法启动一个定时器,用以计算一个操作的持续时间。 定时器由一个唯一的 label 标识。 当调用 console.timeEnd() 时,可以使用相同的 label 来停止定时器,并以毫秒为单位将持续时间输出到 stdout。 定时器持续时间精确到亚毫秒。

console.time('lb1');
for (let i = 0; i < 100; i++) {}
console.timeEnd('lb1');
// 打印 lb1: 23.43ms
  1. 其他方法
说明 实例
打印堆栈跟踪在代码 console.trace([message][, ...args])
计数器的显示标签 console.count([label])
重置指定 label 的内部计数器。 console.countReset([label='default'])
清空控制台 console.clear()
断言 console.assert(value[, message][, ...args])

console的方法还比较多,这里就不一一列举了,有兴趣的可以直接参考中文文档

定时器

node提供了全局的3个设置定时器方法:

  • setImmediate(callback[, ...args])
  • setInterval(callback, delay[, ...args])
  • setTimeout(callback, delay[, ...args])

另外对应3个取消定时器的方法

  • clearImmediate(immediate)
  • clearInterval(timeout)
  • clearTimeout(timeout)

三个方法,使用上基本都表现一致,这里只说一种情况,其他类比。

参数说明:
  callback <Function> 当定时器到点时要调用的函数。
  delay <number> 调用 callback 之前要等待的毫秒数。
  ...args <any> 当调用 callback 时要传入的可选参数。
var timer = setTimeout(()=>{
  console.log(123);
}, 100);

// .... js代码

clearTimeout(timer);

callback 可能不会精确地在 delay 毫秒被调用。 Node.js 不能保证回调被触发的确切时间,也不能保证它们的顺序。 回调会在尽可能接近所指定的时间上调用。
注意:当 delay 大于 2147483647 或小于 1 时,delay 会被设为 1。

其他全局变量

另外全局还提供了 Buffer、模块相关变量、process等全局变量。

这些内容,等我们后续章节再详细介绍。

到此为止,您如果熟悉前端开发的话,这不就是前端js移到了nodejs上执行了吗?的确如此,但是这运行的环境已经脱离了浏览器,是直接运行在操作系统之上了。

那么nodejs背后是怎样运行的?模块机制是怎么搞到的?且看下回再解。


参考:

  1. NodeJs 官网文档
  2. MDN 文档

老马免费视频教程

返回教程列表首页

github地址:https://github.com/malun666/aicoder_node

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容

  • Node.js是目前非常火热的技术,但是它的诞生经历却很奇特。 众所周知,在Netscape设计出JavaScri...
    w_zhuan阅读 3,612评论 2 41
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,639评论 18 139
  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 7,731评论 2 17
  • Node.js是目前非常火热的技术,但是它的诞生经历却很奇特。 众所周知,在Netscape设计出JavaScri...
    Myselfyan阅读 4,066评论 2 58
  • 相识三年,却从未说出那句话 当我们已是向前,一去难回头的箭 少年已经离开,却不知花儿仍在光阴的原点 花儿知道,两年...
    小帅在成长阅读 285评论 0 0