详细介绍 Node.js 模块化

目录

[1. 认识模块化](#1. 认识模块化)

[1.1. 什么是模块化?](#1.1. 什么是模块化?)

[1.2. 模块之间如何联系?](#1.2. 模块之间如何联系?)

[1.3. Node.js 支持哪 2 种模块化标准(特定语法)?](#1.3. Node.js 支持哪 2 种模块化标准(特定语法)?)

[1.4. CommonJS 标准](#1.4. CommonJS 标准)

[1.4.1. 需求](#1.4.1. 需求)

[1.4.2. 使用](#1.4.2. 使用)

[1.4.3. 需求代码如下:](#1.4.3. 需求代码如下:)

[1.5. ECMAScript 标准 - 默认导出和导入](#1.5. ECMAScript 标准 - 默认导出和导入)

[1.5.1. 需求](#1.5.1. 需求)

[1.5.2. 默认标准使用:](#1.5.2. 默认标准使用:)

[1.5.3. 注意](#1.5.3. 注意)

[1.5.4. 需求代码如下:](#1.5.4. 需求代码如下:)

[1.6. 如何让 Node.js 切换模块标准为 ECMAScript?](#1.6. 如何让 Node.js 切换模块标准为 ECMAScript?)

[1.7. ECMAScript 标准 - 命名导出和导入](#1.7. ECMAScript 标准 - 命名导出和导入)

[1.7.1. 需求](#1.7.1. 需求)

[1.7.2. 命名标准使用](#1.7.2. 命名标准使用)

[1.7.3. 需求代码如下:](#1.7.3. 需求代码如下:)

[1.8. ECMAScript 标准 - 默认导出和导入和命名导出和导入如何选择 ?](#1.8. ECMAScript 标准 - 默认导出和导入和命名导出和导入如何选择 ?)


1. 认识模块化

1.1. 什么是模块化?

  • 定义
  • 概念:项目是由很多个模块文件组成的
  • 好处:提高代码复用性,按需加载,独立作用域
  • 使用:需要标准语法导出和导入进行使用

1.2. 模块之间如何联系?

  • 使用特定语法,导出和导入使用

1.3. Node.js 支持哪 2 种模块化标准(特定语法)?

  • CommonJS 标准语法(默认)
  • ECMAScript 标准语法

1.4. CommonJS 标准

1.4.1. 需求
  • 定义 utils.js 模块,封装基地址和求数组总和的函数
1.4.2. 使用
  • 导出:module.exports = {}
  • 导入:require('模块名或路径')

内置模块:直接写名字(例如:fs,path,http)

自定义模块:写模块文件路径(例如:./utils.js)

1.4.3. 需求代码如下:
javascript 复制代码
/**
 * 目标:基于 CommonJS 标准语法,封装属性和方法并导出
 */
const baseURL = 'http://hmajax.itheima.net'
const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)

// 导出
module.exports = {
  url: baseURL,
  arraySum: getArraySum
}
javascript 复制代码
/**
 * 目标:基于 CommonJS 标准语法,导入工具属性和方法使用
 */
// 导入
const obj = require('./utils.js')
console.log(obj)
console.log(obj.url)
const result = obj.arraySum([5, 1, 2, 3])
console.log(result)

1.5. ECMAScript 标准 - 默认导出和导入

1.5.1. 需求
  • 封装并导出基地址和求数组元素和的函数
1.5.2. 默认标准使用:
  • 导出:export default {}
  • 导入:import 变量名 from '模块名或路径'
1.5.3. 注意
  • Node.js 默认支持 CommonJS 标准语法
  • 如需使用 ECMAScript 标准语法,在运行模块所在文件夹新建 package.json 文件,并设置 { "type" : "module" }
1.5.4. 需求代码如下:
javascript 复制代码
/**
 * 目标:基于 ECMAScript 标准语法,封装属性和方法并"默认"导出
 */
const baseURL = 'http://hmajax.itheima.net'
const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)

// 默认导出
export default {
  url: baseURL,
  arraySum: getArraySum
}
javascript 复制代码
/**
 * 目标:基于 ECMAScript 标准语法,"默认"导入,工具属性和方法使用
 */
// 默认导入
import obj from './utils.js'
console.log(obj)
const result = obj.arraySum([10, 20, 30])
console.log(result)
javascript 复制代码
{
  "type": "module"
}

1.6. 如何让 Node.js 切换模块标准为 ECMAScript?

  • 运行模块所在文件夹,新建 package.json 并设置 { "type" : "module" }

1.7. ECMAScript 标准 - 命名导出和导入

1.7.1. 需求
  • 封装并导出基地址和求数组元素和的函数
1.7.2. 命名标准使用
  • 导出:export 修饰定义语句
  • 导入:import { 同名变量 } from '模块名或路径
1.7.3. 需求代码如下:
javascript 复制代码
/**
 * 目标:基于 ECMAScript 标准语法,封装属性和方法并"命名"导出
 */
export const baseURL = 'http://hmajax.itheima.net'
export const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)
javascript 复制代码
/**
 * 目标:基于 ECMAScript 标准语法,"命名"导入,工具属性和方法使用
 */
// 命名导入
import {baseURL, getArraySum} from './utils.js'
console.log(obj)
console.log(baseURL)
console.log(getArraySum)
const result = getArraySum([10, 21, 33])
console.log(result)
javascript 复制代码
{
  "type": "module"
}

1.8. ECMAScript 标准 - 默认导出和导入和命名导出和导入如何选择 ?

  • 按需加载,使用命名导出和导入
  • 全部加载,使用默认导出和导入
相关推荐
wangruofeng43 分钟前
Playwright 深度调研:为什么它成了浏览器自动化的新底座
前端·测试
李白的天不白3 小时前
SSR服务端渲染
前端
卷帘依旧4 小时前
SSE(Server-Sent Events)完全指南
前端
码云之上4 小时前
万星入坞:我们如何用三层插件体系干掉巨石应用
前端·架构·前端框架
kyriewen4 小时前
一口气讲清楚 Monorepo、Turborepo、pnpm、Changesets 到底是什么?
前端·架构·前端工程化
IT_陈寒5 小时前
React性能优化踩的坑,这个错你可能也会犯
前端·人工智能·后端
zhangxingchao5 小时前
AI应用开发三:RAG技术与应用
前端·人工智能·后端
摘星小杨5 小时前
如何在前端循环调取接口,实时查询数据
开发语言·前端·javascript
Hilaku6 小时前
从搜索排名到 AI 回答? 先聊一聊 AI 可见度工具 BuildSOM !
前端·javascript·程序员
zzmgc46 小时前
纯静态 + Web Worker + 虚拟滚动:我是怎么让浏览器吃下 10MB JSON 不卡的
前端·架构