前端模块化

本节目标

  • 介绍
  • CommonJS标准
  • ECMASript标准
  • 包管理器
  • 全局软件包

介绍

定义

在Node.js中, 每个文件都被视为一个单独的模块, 方便项目的管理

CommonJS模块是Node.js打包JS代码的原始方式, 一般用于Node.js项目中

Node.js还支持浏览器和其他JS运行时使用的ECMAScript模块标准, 一般用在前端项目中

说明

  • 项目就是由多个模块文件组成的
  • 好处是提高代码复用性, 实现按需加载,文件是独立的作用域
  • 模块之间使用导入导出语法关联
  • Node.js默认使用CommonJS规范

CommonJS规范

语法

  • 导出模块: module.exports = {}
  • 导入模块: require(' 模块名或路径 ')
  • 内置模块直接写名字 (fs/path/http)
  • 自定义模块写文件路径 (相对路径)

体验

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

// 导出
module.exports = {
  baseURL,
  getArraySum
}

/**
 * 目标:基于 CommonJS 标准语法,导入工具属性和方法使用
 */
// 导入
const utils = require('./utils')

// 使用变量
console.log(utils.baseURL);

// 使用方法
const arr = [1, 2, 3, 4, 5]
const sum = utils.getArraySum(arr)
console.log(sum);

ECMAScript标准

默认导出

  • 导出: export default {}
  • 导入: import 变量名 from '模块名或路径'
  • 前提: 在运行模块所在文件夹, 新建package.json文件, 设置 { "type": "module" }
  • 场景: 成员全部导出时, 使用默认导出和导入

体验

复制代码
/**
 * 目标:基于 ECMAScript 标准语法,封装属性和方法并"默认"导出
 */
const baseURL = 'http://hmajax.itheima.net'
const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)

// 默认导出
export default {
  baseURL,
  getArraySum
}

/**
 * 目标:基于 ECMAScript 标准语法,"默认"导入,工具属性和方法使用
 */
// 默认导入
import utils from './utils.js'

// 使用变量
console.log(utils.baseURL);

// 使用方法
const sum = utils.getArraySum([1, 2, 3, 4, 5])
console.log(sum);

按需导出

  • 导出: export 修饰定义语句
  • 导入: import { 同名变量 } from '模块名或路径'
  • 前提: 在运行模块所在文件夹, 新建package.json文件, 设置 { "type": "module" }
  • 场景: 只导出个别成员时, 使用按需导出和导入

体验

复制代码
/**
 * 目标:基于 ECMAScript 标准语法,封装属性和方法并"命名"导出
 */
export const baseURL = 'http://hmajax.itheima.net'
export const getArraySum = arr => arr.reduce((sum, item) => sum += item, 0)

/**
 * 目标:基于 ECMAScript 标准语法,"命名"导入,工具属性和方法使用
 */
// 命名导入
import { baseURL, getArraySum } from './utils.js'

// 使用变量
console.log(baseURL)

// 使用方法
const result = getArraySum([10, 21, 33])
console.log(result)

立即执行

  • 语法: import '资源路径'
  • 目的: 只是为了让 目标文件参与运行

体验

复制代码
import '@/utils/auth.js'
import './index.css'

将模块, 代码, 其他资料聚合在一个文件夹中, 形成了包

分类

  • 根据作用不同, 包分为两类
  • 项目包: 主要用于编写项目和业务逻辑
  • 软件包: 封装了工具和方法提高开发效率

说明

  • 所有的包, 根目录中, 必须有package.json文件 (记录包的清单信息)
  • 导入软件包时, 默认导入index.js文件作为入口文件
  • 找不到index.js文件时, 找package.json文件main属性指定的文件

包管理器

包管理器的作用就是下载和管理Node.js依赖包的. npm是Node.js标准的软件包管理器

使用

  1. 初始化清单文件: npm init -y (创建package.json文件, 有则略过)
  2. 下载软件包: npm i 包名
  3. 删除软件包: npm uni 包名
  4. 使用软件包

过程

  1. 创建清单文件package.json
  2. 使用npm命令下载软件包
  3. 软件包会被存放到node_modules文件夹中
  4. 软件包的信息会被记录到清单文件的dependencies选项中
  5. 该软件包的版本会被固话到package-lock.json文件中
  6. 软件包下载成功, 可以导入使用了

安装全部依赖

传递项目的过程中, 不会携带node_modules文件夹, 拿到项目后, 使用 npm i 命令下载全部依赖软件包即可

因为 package.json文件中记录了项目中所需的依赖包及其版本信息

全局软件包

本地软件包: 当前项目中使用, 封装了属性和方法, 存在于node_modules中

全局软件包: 本机所有项目使用, 封装了命令和工具, 存放于系统设置的位置

nodemon

替代node命令, 可以检测代码更改, 自动重启程序

使用

  1. 安装: npm i nodemon -g (-g代表安装到全局环境中)
  2. 使用: nodemine 代执行文件
相关推荐
xianxin_5 分钟前
CSS Dimension(尺寸)
前端
小宋搬砖第一名5 分钟前
前端包体积优化实战-从 352KB 到 7.45KB 的极致瘦身
前端
陈随易6 分钟前
前端之虎陈随易:2025年8月上旬总结分享
前端·后端·程序员
草巾冒小子10 分钟前
天地图应用篇:增加全屏、图层选择功能
前端
universe_0129 分钟前
day25|学习前端js
前端·笔记
Zuckjet34 分钟前
V8 引擎的性能魔法:JSON 序列化的 2 倍速度提升之路
前端·chrome·v8
MrSkye34 分钟前
🔥React 新手必看!useRef 竟然不能触发 onChange?原来是这个原因!
前端·react.js·面试
wayman_he_何大民41 分钟前
初识机器学习算法 - AUM时间序列分析
前端·人工智能
juejin_cn42 分钟前
前端使用模糊搜索fuse.js和拼音搜索pinyin-match提升搜索体验
前端
....4921 小时前
Vue3 + Element Plus 实现可搜索、可折叠、可拖拽的部门树组件
前端·javascript·vue.js