详解module.exports与exports,export与export default,import 与require

简介: 详解module.exports与exports,export与export default,import 与require

导出简介(里面有小细节请仔细阅读)

变量的导出涉及到四个关键字module.exports与exports,export与export default,

其中module.exports与exports是符合CommonJS模块规范的。

export与export default是es6用来导出模块的。

module.exports与exports

  • module是一个对象,代指的整个js文件,而他的exports属性就是该js文件对外暴露的对象,只要是module.exports的属性内的值都能被访问到(包括字符串,数字,对象,函数)。
  • exports指向了module.exports就相当于在js文件开头添加了这样一段代码
var exports = module.exports;

总之我们只要记住一点:module.exports指向的东西,就是我们要导出的东西

1.该js文件要导出的值即为test

const test=1;
  module.exports ={test};
  console.log(module.exports)

2.该js文件要导出的值即为test1和test2

const test1="test1";
const test2= "test2";
module.exports ={test1};
module.exports.test2 =test2;
console.log(module.exports)

3. 注意这里我是先给module.exports.test2赋值,然后给module.exports赋值,因此{test1}覆盖了原来的test2,因此module.exports中只有test1

const test1="s";
  const test2= "ss";
  const test3="sss";
  module.exports.test2 =test2;
  module.exports ={test1};
  console.log(module.exports)

4. 该js文件要导出的值即为test2

const test1="s";
  const test2= "ss";
  const test3="sss";
  exports.test2 = test2;
  console.log(module.exports)

5. 注意这里(注意点),module.exports ={test1};改变了module.exports指向的引用,exports还指向之前的module.exports引用,因此无论exports.test2 = test2;在哪里执行都不能改变该js文件索要暴露的值。所以如果要改变module.exports指向的引用,就不要使用exports

 

export与export default

  • 这两个是es6的语法,在小程序中也是可以使用的
  • export与export default都是用来导出变量的,并且他们两个作用与exports相同,只是语法不同
  • 二者同样是给module.exports赋值,export可以赋多个值,export default只能赋一个值(只能使用一次).
  • export后面跟的是声明或者语句,export default后面跟的是表达式

1.根据输出可知:export default test1;等价于exports.default = test1; export {test2};等价于exports.test2 = test2;

const test1="s";
  const test2= "ss";
  const test3="sss";
  export  default test1;
  export {test2};
  export const test4="ssss";
  console.log(module.exports)

(坑)export {}这个语法比较特殊,{}花括号中,必须是提前定义好的

(1)正确

const test1 = "test1";
export {
  test1//这种可以
};
console.log(module.exports)

(2)错误

export {
  test1:1
};
console.log(module.exports)

2.可见:要想使用export或者export defalut 就不能改变module.exports指向的引用

const test1="s";
  const test2= "ss";
  const test3="sss";
  const test4="ssss";
  export  default test1;
  export {test2};
  module.exports ={test3};//这里进行了指向更改
  export {test4};
  console.log(module.exports)

(坑)上面第七行代码进行了,执行module的指向更改,后续如果引入的话,就只会引入module.exports最新的一次指向

导入简介

我们知道了如何导出变量,那肯定还得知道如何导入

使用require 与import来导入

require 是是符合CommonJS模块规范的。import是es6用来导出模块的。

require 可以在js文件中的任意位置使用,import只能在文件开头使用

require

require比较好理解,他可以直接获取module.exports的对象,进而使用其中的属性和方法

//test.js中
const test1="s";
const test2= "ss";
const test3="sss";
const test4="ssss";
export  default test1;
export {test2};
exports.test3=test3;
module.exports.test4=test4;
//引用的文件中
var test = require("../../utils/test.js");
console.log(test)

import

import是直接获取module.exports对象的属性和方法

(注意)如果同时存在自定义的和default那么impor的时候需要注意

方法1、方法2、方法3都在下面的代码里面

//test.js中
  const test1="s";
  const test2= "ss";
  const test3="sss";
  const test4="ssss";
  export  default test1;//导出默认
  export {test2};
  exports.test3=test3;
  module.exports.test4=test4;
  //引用的文件中,import在文件开头
    //情况1(用法)
  import {test2,test3,test4} from "../../utils/test.js"//这种情况下对test2 test3 test4进行单独导出
    //情况2(用法)
    import test0 from "../../utils/test.js"//这种情况下只对module.exports中的default的值单独导出并且赋值给test0
    //情况3(用法)
    import * as all from "../../utils/test.js"//这种情况下将module.exports的所有值都付给all

export defalut 就是默认输出的值,在使用import时,要想使用这个默认的值就需要只获取一个值(不加大括号,变量名随便写)

//test.js中
  const test1="s";
  export  default test1;
  //引用的文件中,import在文件开头
  import SuiBianXie from "../../utils/test.js"
  console.log(SuiBianXie)

require和import区别

区别1:模块加载的时间

require:运行时加载

import:编译时加载(效率更高)【由于是编译时加载,所以import命令会提升到整个模块的头部】

区别2:模块的本质

require:模块就是对象,输入时必须查找对象属性

import:ES6 模块不是对象,而是通过 export 命令显式指定输出的代码,再通过 import 命令输入(这也导致了没法引用 ES6 模块本身,因为它不是对象)。由于 ES6 模块是编译时加载,使得静态分析成为可能。有了它,就能进一步拓宽 JavaScript 的语法,比如引入宏(macro)和类型检验(type system)这些只能靠静态分析实现的功能。

区别3:严格模式

CommonJs模块和ES6模块的区别:

(1)CommonJs模块默认采用非严格模式

(2)ES6 的模块自动采用严格模式,不管你有没有在模块头部加上 “use strict”;

(3)CommonJS 模块输出的是一个值的拷贝,ES6 模块输出的是值的引用

ES6 模块之中,顶层的 this 指向 undefined ,即不应该在顶层代码使用 this

目录
相关文章
|
8月前
|
Ubuntu 安全 Linux
宝塔Linux面板安装教程
这是一篇关于宝塔Linux面板安装教程的文章,支持CentOS/Ubuntu/Deepin/Debian/Fedora系统。文章详细列出了各系统的安装脚本命令,并提供更新升级脚本、安装后操作指南及注意事项。重点包括开放必要端口、解决权限问题、查看安装日志以及推荐的安全设置,如启用登录限制和定期更新面板。若遇问题可参考宝塔官方论坛或寻求技术支持。
690 0
|
JavaScript 前端开发
如何在JavaScript中替换字符串:一篇详细指南
如何在JavaScript中替换字符串:一篇详细指南
|
数据采集 应用服务中间件 Go
开源的键鼠共享工具「GitHub 热点速览」
开源的键鼠共享工具「GitHub 热点速览」
|
监控 安全 算法
提升编程效率的利器: 解析Google Guava库之RateLimiter优雅限流(十)
提升编程效率的利器: 解析Google Guava库之RateLimiter优雅限流(十)
|
传感器 监控 安全
预防非法访问
【8月更文挑战第19天】
402 7
|
前端开发
运用CSS伪类与属性,巧妙实现背景图片旋转效果
运用CSS伪类与属性,巧妙实现背景图片旋转效果
268 0
|
JavaScript 前端开发
node.js 导入导出模块(CommonJS模块化规范,ES6模块化规范)
node.js 导入导出模块(CommonJS模块化规范,ES6模块化规范)
263 1
|
存储 监控 JavaScript
使用Node.js构建实时聊天应用的技术指南
【5月更文挑战第12天】本文指导使用Node.js、Express.js和Socket.IO构建实时聊天应用。技术栈包括Node.js作为服务器环境、WebSocket协议、Express.js作为Web框架和Socket.IO处理实时通信。步骤包括项目初始化、安装依赖、搭建服务器、实现实时聊天功能、运行应用以及后续的完善和部署建议。通过这个指南,读者可以学习到创建简单实时聊天应用的基本流程。
|
JavaScript 前端开发
【前端 - Vue】关于ESlint代码规范及格式化插件
【前端 - Vue】关于ESlint代码规范及格式化插件
|
机器学习/深度学习 分布式计算 监控
大模型开发:你如何使用大数据进行模型训练?
在大数据模型训练中,关键步骤包括数据准备(收集、清洗、特征工程、划分),硬件准备(分布式计算、并行训练),模型选择与配置,训练与优化,监控评估,以及模型的持久化与部署。过程中要关注数据隐私、安全及法规遵循,利用技术进步提升效率和性能。
2587 2