登录  /  注册
首页 > web前端 > js教程 > 正文

认识nodejs中的全局对象,看看它与浏览器中全局对象的区别

青灯夜游
发布: 2021-12-03 19:00:26
转载
2111人浏览过

本篇文章带大家了解一下node中的全局对象,介绍一下nodejs全局对象与浏览器中的全局对象的区别,希望对大家有所帮助!

认识nodejs中的全局对象,看看它与浏览器中全局对象的区别

Node.js中,一个.js文件就是一个完整的作用域(module,模块)。因此 var 声明的变量只在当前.js文件中有效,而不是全局有效。 而global全局对象是独立于所有的.js(module,模块)之上的。

而在浏览器中的最顶层全局对象是window,var声明的变量默认绑定到window对象上

1. 全局对象的定义

概念:在程序的任何地方都可以访问的对象,称之为全局对象。对象的属性称为全局变量。

2. NodeJS中的全局变量总结

这里我们总结下在nodejs中,我们常用的全局变量有哪些

2.1 Buffer类

Buffer,我们也可以称为“缓冲区”,其功能就是在内存中开辟一片区域,用来存放二进制数据。

2.2 __dirname

__dirname,返回当前模块文件解析过后所在的文件夹(目录)的绝对路径。

请记住,__dirname并不是真正的全局变量。

2.3 __filename

__filename,返回当前模块文件被解析过后的绝对路径。

请记住,__filename并不是真正的全局变量。

2.4 <span style="font-size: 18px;">module</span>

请记住,module并不是真正的全局变量。

2.5 <span style="font-size: 18px;">require()</span>

请记住,require()并不是真正的全局变量。

2.6 <span style="font-size: 18px;">exports</span>

请记住,exports并不是真正的全局变量。

2.7 <span style="font-size: 18px;">setImmediate</span><span style="font-size: 18px;">clearImmediate</span>

2.8 <span style="font-size: 18px;">setTimeout</span><span style="font-size: 18px;">clearTimeout</span>

2.9 <span style="font-size: 18px;">setInterval</span><span style="font-size: 18px;">clearInterval</span>

2.10 <span style="font-size: 18px;">console</span>

用于打印到标准输出和标准错误

2.11 <span style="font-size: 18px;">process</span>

process 对象提供有关当前 Node.js 进程的信息并对其进行控制。

2.12 <span style="font-size: 18px;">URL</span>

URL 用于网址处理和解析的实用工具

2.13 <span style="font-size: 18px;">events</span>

events模块是Node对“发布/订阅”模式(publish/subscribe)的实现。一个对象通过这个模块,向另一个对象传递消息。该模块通过EventEmitter属性,提供了一个构造函数。

3. globalThis

3.1 globalThis是什么?

JS 语言越来越多被用于各种环境中。除了最常见的浏览器之外,它还可以在服务器、智能手机甚至机器人硬件上运行。

每个环境都有其自己的对象模型,并提供了不同的语法来访问全局对象。例如,在 Web 浏览器中,可以通过window,self或frames访问全局对象。但是,在 Node.js 中,这些属性不存在,而必须使用global。

globalThis旨在通过定义一个标准的全局属性来整合日益分散的访问全局对象的方法。该提案被纳入ES2020标准。所有流行的浏览器,包括Chrome 71+、Firefox 65+和Safari 12.1+,都已经支持这项功能。你也可以在Node.js 12+中来使用它。

更多node相关知识,请访问:nodejs 教程!!

以上就是认识nodejs中的全局对象,看看它与浏览器中全局对象的区别的详细内容,更多请关注php中文网其它相关文章!

智能AI问答
PHP中文网智能助手能迅速回答你的编程问题,提供实时的代码和解决方案,帮助你解决各种难题。不仅如此,它还能提供编程资源和学习指导,帮助你快速提升编程技能。无论你是初学者还是专业人士,AI智能助手都能成为你的可靠助手,助力你在编程领域取得更大的成就。
相关标签:
来源:掘金社区网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
作者最新文章
最新问题
关于CSS思维导图的课件在哪? 课件
凡人来自于2024-04-16 10:10:18
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2024 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号