【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

相关文章
|
5天前
|
JSON JavaScript 前端开发
JavaScript实现字符串转json对象的方法
JavaScript实现字符串转json对象的方法
|
1天前
|
JavaScript 前端开发 索引
JS遍历数组里数组下的对象,根据数组中对象的某些值,组合成新的数组对象
这篇文章介绍了如何在JavaScript中遍历数组里数组下的对象,并根据对象的某些属性值组合成一个新的数组对象。主要内容包括使用ES6的`for...of`循环来遍历数组对象,然后根据需要提取对象中的属性值,并将它们放入新的对象中,最终形成一个新的对象数组以供使用。
|
1天前
|
JSON JavaScript 前端开发
如何检查 JavaScript 对象是否为空
【8月更文挑战第18天】
15 0
如何检查 JavaScript 对象是否为空
|
4天前
|
JavaScript 前端开发
JavaScript BOM 的概念(浏览器对象模型)
JavaScript BOM 的概念(浏览器对象模型)
12 1
|
5天前
|
JavaScript 前端开发
JavaScript基础&实战(5)js中的数组、forEach遍历、Date对象、Math、String对象
这篇文章介绍了JavaScript中的数组、Date对象、Math对象以及包装类(String、Number、Boolean),并详细讲解了数组的创建、方法(如forEach、push、pop、unshift、slice、splice)和遍历操作,以及工厂方法创建对象和原型对象的概念。
JavaScript基础&实战(5)js中的数组、forEach遍历、Date对象、Math、String对象
|
5天前
|
JavaScript 前端开发
JavaScript基础&实战(4)js中的对象、函数、全局作用域和局部作用域
这篇文章介绍了JavaScript中对象的基本概念和操作,包括对象属性和方法的使用、对象字面量的创建、函数的定义和作用域的概念,以及全局作用域和局部作用域的区别和特性。
JavaScript基础&实战(4)js中的对象、函数、全局作用域和局部作用域
|
4天前
|
JavaScript
js中有哪些函数?
js中有哪些函数?
5 0
|
4天前
|
JavaScript 前端开发
JavaScript声明变量的几种方式
JavaScript声明变量的几种方式
10 0
|
5天前
|
JavaScript 前端开发 Java
JavaScript 特殊函数
JavaScript 特殊函数
6 0
|
5天前
|
JavaScript 前端开发
JavaScript 函数中break,continue,return 的区别
JavaScript 函数中break,continue,return 的区别
13 0