【Node.js】全局可用变量、函数和对象

简介: 在Node.js中提供了一些全局可用的变量、函数和对象,全局就是不需要进行模块加载,可以直接使用的。其中包括全局作用域的函数和对象。也包括不在全局作用域,而在每个模块作用域都存在的变量、函数和对象,在全局可用,但不是golbal对象的属性。

前言


在Node.js中提供了一些全局可用的变量、函数和对象,全局就是不需要进行模块加载,可以直接使用的。其中包括全局作用域的函数和对象。也包括不在全局作用域,而在每个模块作用域都存在的变量、函数和对象,在全局可用,但不是golbal对象的属性。


_dirname和_filename变量


Node.js提供了两个与文件操作相关全局可用变量_dirname和_filename变量。其中_dirname变量表示当前文件所在目录,_filename变量表示当前正在执行的脚本的文件名。


全局函数


setTimeout(cb,ms)


全局函数在指定的毫秒(ms)数后执行指定函数(cb)。setTimeout()只执行一次指定函数。 setTimeout()返回值可以作为clearTimeout的参数。


如下,我们创建一个函数,然后使用setTimeout来3秒后执行该函数。


function hello(){
    console.log("Hello,reader!");
}
// 3秒后执行hello()函数
setTimeout(hello,3000);


在终端进行运行,3秒以后将输出函数中的内容。


5a60e2f32a4342e8a2550220c2fddbda.png


clearTimeout(t)


全局函数用于停止一个之前通过setTimeout()创建的定时器。参数t是通过setTimeout()函数创建的计时器。


如下,我们创建一个函数,然后使用setTimeout来3秒后执行该函数。用clearTimeout清除。


function hello(){
    console.log("Hello,reader!");
}
// 3秒后执行hello()函数
var t = setTimeout(hello,3000);
// 清除定时器
clearTimeout(t);


终端运行后,没有任何结果


43ab18db49ed43a389c95fccc8bd0152.png


setInterval(cb,ms)


setInterval和setTimeout类似,不过setInterval会在每毫秒后(并非精确的毫秒,ms)执行一次指定函数(cb)。setInterval返回值可以作为clearInterval的参数。setInterval() 方法会不停地调用函数,直到 clearInterval() 被调用或窗口被关闭。


function hello(){
    console.log("Hello,reader!");
}
// 3秒后执行hello()函数
setInterval(hello,3000);


运行后每隔3秒会出现一个Hello,reader!直到终止程序(ctrl+C)。


4b09737c62264096b429e768a3df4f50.png


clearInterval(t)


用于停止setInterval定时器,这样回调函数就不会被执行。


function hello(){
    console.log("Hello,reader!");
}
// 3秒后执行hello()函数
var t = setInterval(hello,3000);
// 清除定时器
clearInterval(t);


运行后没有任何结果。


c240a210bc9e4264922757a8962ccd5a.png


setImmediate(cb)


用于延迟调用cb函数。cb将在I/O事件回调之后,setTimeout和setInterval回调之前调用。setImmediate的返回值可以作为clearImmediate的参数。


function hello(){
    console.log("Hello,reader!");
}
setTimeout(hello,3000);
setImmediate(hello);


运行后会出现2个Hello,reader! 其中第2个是在出现第一个“Hello,reader! ”后,间隔3秒才出现的。


94adce61946b4af5a4e87d8b894cbcf6.png


clearImmediate()


用于停止触发回调函数。


console对象


我们在学习中,经常使用到console.log()语句,console对象就是一个全局对象,用于提供控制台标准输出。


console.info([data][,…])


返回信息性消息,这个命令与console.log差别不大,除了在chrome中输出文字外,其余的会显示一个蓝色的惊叹号。


console.error([data][,…])


输出错误消息,控制台在出现错误时会显示是红色的叉叉。


6f70f417187340e287edbd8d9e6b4ed2.png


console.warn([data][,…])


输出警告消息,控制台出现黄色的惊叹号。


8c150aba271348b3bbac5261bf245e3a.png


console.dir(obj[,options])


用来对一个对象进行检查,并以易于阅读和打印的格式显示。


7f5a150c4a4b42dfb5e37709e39e006e.png


console.time(label)


输出时间,表示计时开始。


03944623374241389a549eeca49ff820.png


console.timeEnd(label)


结束时间,表示计时结束。


console.trace(message[,…])


当前执行的代码在堆栈中的调用路径,这个对测试函数运行很有帮助。


console.assert(value[,message][,…])


用于判断某个表达式或变量是否为真,有2个参数,第一个参数是表达式,第二个参数是字符串。只有当第一个参数为false时,才会输出第二个参数,否则不会有任何结果。


总结


以上就是今天的学习内容啦~

如果有兴趣的话可以订阅专栏,持续更新呢~

咱们下期再见~


2a355db889024ba1a5da014fec691153.gif

相关文章
|
2月前
|
JavaScript 前端开发
如何在 JavaScript 中使用 __proto__ 实现对象的继承?
使用`__proto__`实现对象继承时需要注意原型链的完整性和属性方法的正确继承,避免出现意外的行为和错误。同时,在现代JavaScript中,也可以使用`class`和`extends`关键字来实现更简洁和直观的继承语法,但理解基于`__proto__`的继承方式对于深入理解JavaScript的面向对象编程和原型链机制仍然具有重要意义。
|
2月前
|
Web App开发 JavaScript 前端开发
如何确保 Math 对象的方法在不同的 JavaScript 环境中具有一致的精度?
【10月更文挑战第29天】通过遵循标准和最佳实践、采用固定精度计算、进行全面的测试与验证、避免隐式类型转换以及持续关注和更新等方法,可以在很大程度上确保Math对象的方法在不同的JavaScript环境中具有一致的精度,从而提高代码的可靠性和可移植性。
|
2月前
|
JSON 前端开发 JavaScript
JavaScript中对象的数据拷贝
本文介绍了JavaScript中对象数据拷贝的问题及解决方案。作者首先解释了对象赋值时地址共享导致的值同步变化现象,随后提供了五种解决方法:手动复制、`Object.assign`、扩展运算符、`JSON.stringify`与`JSON.parse`组合以及自定义深拷贝函数。每种方法都有其适用场景和局限性,文章最后鼓励读者关注作者以获取更多前端知识分享。
30 1
JavaScript中对象的数据拷贝
|
2月前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
48 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
2月前
|
前端开发 JavaScript
如何在 JavaScript 中访问和修改 CSS 变量?
【10月更文挑战第28天】通过以上方法,可以在JavaScript中灵活地访问和修改CSS变量,从而实现根据用户交互、页面状态等动态地改变页面样式,为网页添加更多的交互性和动态效果。在实际应用中,可以根据具体的需求和场景选择合适的方法来操作CSS变量。
|
2月前
|
前端开发 JavaScript 数据处理
CSS 变量的作用域和 JavaScript 变量的作用域有什么不同?
【10月更文挑战第28天】CSS变量和JavaScript变量虽然都有各自的作用域概念,但由于它们所属的语言和应用场景不同,其作用域的定义、范围、覆盖规则以及与其他语言特性的交互方式等方面都存在明显的差异。理解这些差异有助于更好地在Web开发中分别运用它们来实现预期的页面效果和功能逻辑。
|
2月前
|
前端开发 JavaScript UED
如何使用 JavaScript 动态修改 CSS 变量的值?
【10月更文挑战第28天】使用JavaScript动态修改CSS变量的值可以为页面带来更丰富的交互效果和动态样式变化,根据不同的应用场景和需求,可以选择合适的方法来实现CSS变量的动态修改,从而提高页面的灵活性和用户体验。
|
2月前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
2月前
|
JavaScript 前端开发 图形学
JavaScript 中 Math 对象常用方法
【10月更文挑战第29天】JavaScript中的Math对象提供了丰富多样的数学方法,涵盖了基本数学运算、幂运算、开方、随机数生成、极值获取以及三角函数等多个方面,为各种数学相关的计算和处理提供了强大的支持,是JavaScript编程中不可或缺的一部分。
|
3月前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
下一篇
开通oss服务