前端模块化

本节目标

  • 介绍
  • 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 代执行文件
相关推荐
会发光的猪。6 分钟前
vue中el-select选择框带搜索和输入,根据用户输入的值显示下拉列表
前端·javascript·vue.js·elementui
旺旺大力包23 分钟前
【 Git 】git 的安装和使用
前端·笔记·git
PP东28 分钟前
ES学习class类用法(十一)
javascript·学习
海威的技术博客33 分钟前
JS中的原型与原型链
开发语言·javascript·原型模式
雪落满地香39 分钟前
前端:改变鼠标点击物体的颜色
前端
余生H1 小时前
前端Python应用指南(二)深入Flask:理解Flask的应用结构与模块化设计
前端·后端·python·flask·全栈
outstanding木槿1 小时前
JS中for循环里的ajax请求不数据
前端·javascript·react.js·ajax
酥饼~1 小时前
html固定头和第一列简单例子
前端·javascript·html
一只不会编程的猫1 小时前
高德地图自定义折线矢量图形
前端·vue.js·vue
所以经济危机就是没有新技术拉动增长了1 小时前
二、javascript的进阶知识
开发语言·javascript·ecmascript