Node.JS(4)--模块、exports和module

文章介绍了Node.js的模块系统,包括核心模块和文件模块的使用,强调了exports和module.exports的区别。此外,还讨论了JavaScript的基本数据类型和引用数据类型的特性,以及如何通过exports和module.exports导出模块内容。
摘要由CSDN通过智能技术生成

模块

分为两大类

核心模块

  • 由node引擎提供的模块

  • 核心模块的标识就是模块的名字

var fs=require("fs");

在这里插入图片描述

文件模块

  • 由用户自己创建的模块
  • 文件模块的标识就是文件的路径(绝对路径、相对路径),相对路径用的更多,相对路径使用.或者…开头

在node中有一个全局对象global,它的作用和网页中window类似,在全局中创建的变量都会作为global的属性保存,在全局中创建的函数会作为global的方法保存

arguements表示函数的变量

arguements.callee这个属性保存的是当前执行的函数对象

在这里插入图片描述

如果在arguments.callee后面+“”,代表拼串,会把函数打印出来

console.log(arguments.callee+"");

在这里插入图片描述

当node在执行模块中的代码时,它会首先在代码的最顶部,添加如下代码

function (exports, require, module, __filename, __dirname) {

在代码的最底部,添加如下代码

}

实际上模块中的代码都是包装在一个函数中执行的,并且在函数执行时,同时传递进了5个实参

exports:该对象将变量或函数暴露到外部

require:函数,用来引入外部的模块

module:代表当前模块本身,exports就是module的属性,既可以使用exports到处,也可以使用module.exports导出

console.log(exports);
console.log(module.exports);
console.log(module.exports==exports);

在这里插入图片描述

_filename:当前模块的完整路径

console.log(__filename);

在这里插入图片描述

_dirname:当前模块所在文件夹的完整路径

console.log(__dirname);

在这里插入图片描述

helloModule.js

module.exports={
    name:'猪八戒',
    age:28,
    sayName:function(){
        console.log("我是猪八戒");
    }
}

05.module.js

var hello=require("./helloModule");

console.log(hello.name);
console.log(hello.age);
console.log(hello.sayName);

在这里插入图片描述

基本数据类型

var a=10;
var b=a;
a++;

console.log("a="+a);
console.log("b="+b);

在这里插入图片描述

基本数据类型的值是相互独立的,所以a++后,b不发生改变

可以从堆栈内存中进行分析,在存入变量和值后,a的值10和b的值是独立的,此时a的值变化不影响b的值

在这里插入图片描述

引用数据类型

此时再看到引用变量

var obj=new Object();
obj.name="孙悟空";
var obj2=obj;
obj2.name="猪八戒";

console.log("obj="+obj.name);
console.log("obj2="+obj2.name);

在这里插入图片描述

当出现new时,就需要往堆内存中存放对象,栈内存中存放变量,对象没有名字,只有内存地址(16进制地址),变量的值就是地址值,此时会有指针指向堆内存中的对象

此时加入obj.name时,会加到堆内存中的对象

在这里插入图片描述

当对obj2设置为null,对 obj 没有影响

因为obj2改变的是变量,obj2.name改变的是对象

在这里插入图片描述

exports和module.exports的关系

此时再转回到module.exports和exports

在这里插入图片描述

module.exports改变的是对象,exports改变的是变量的值,此时运行就会报错

在这里插入图片描述

通过exports只能使用.的方式来向外暴露内部变量

exports.xxx=xx;

而module.exports既可以通过.的形式,也可以直接赋值

module.exports.xxx=xx;
//或者
module.exports={...}

通过exports只能使用.的方式来向外暴露内部变量

exports.xxx=xx;

而module.exports既可以通过.的形式,也可以直接赋值

module.exports.xxx=xx;
//或者
module.exports={...}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值