Node二、Node.js 模块化、es6 软件包、Express - 框架

一、Node.js 模块化

在Nodejs中,每个文件都被视为一个单独的模块。
支持 2 种模块化标准 CommonJS 标准语法(默认) ECMAScript 标准语法
模块名或路径:
✓ 内置模块:直接写名字(例如:fs,path,http)
✓ 自定义模块:写模块文件路径(例如:./utils.js)

1.CommonJS

1. 导出:module.exports = { }
2. 导入:require('模块名或路径')
模块之间联系:使用特定语法, 导出 和 导入 使用

2.ECMAScript (es6)

注意:Node.js 默认支持 CommonJS ,使用 ECMAScript 标准语法需要在运行模块所在文件夹新建 package.json 文件,并设置 { "type" : "module" }

默认导入导出

1. 导出:export default {}

javascript 复制代码
const baseURL ='http://hmajax.itheima.net'
const getArraysum = arr => arr.reduce((sum, val) => sum += val, 0)
export default{
对外属性名1:baseURL,
对外属性名2:getArraySum
}

2. 导入:import 变量名 from '模块名或路径'

javascript 复制代码
importobjfrom'模块名或路径"
//obj就等于 export default 导出的对象

按需导入和导出

命名导出和导入

1. 导出:export 修饰定义语句

javascript 复制代码
export const baseURL = 'http://hmajax.itheima.net'
export const getArraysum = arr => arr.reduce((sum, val) => sum += val, 0)

2. 导入:import { 同名变量 } from '模块名或路径'

javascript 复制代码
import{ baseURL,getArraySum }from'模块名或路径'
//baseURL 和 getArraySum 是变量,值为模块内命名导出的同名变量的值

二、软件包

包:将 模块,代码,其他资料 聚合成一个文件夹
包分类项目包 :编写项目和业务逻辑 ,软件包: 封装工具和方法 进行使用

package.json记录包的清单信息

根目录中,必须有 package.json 文件记录 软件包的名字 ,作者, 入口 文件等信息

导入一个包文件夹的时候 默认 导入的是index.js 文件 ,或者 main 属性指定的文件

npm - 软件包管理器

npm 是 Node.js 标准的软件包管理器。作用:下载软件包以及管理版本

(重点)使用npm下载软件包

1.初始化清单文件:npm init -y(得到 package.json 文件,有则略过此命令)

2.下载软件包:npm i 软件包名称

3.使用软件包

(下载的包会存放在当前项目下的 node_modules 中,并记录在 package.json 中)

javascript 复制代码
/**
 * 目标:使用 npm 下载 dayjs 软件包来格式化日期时间
 *  1. (可选)初始化项目清单文件,命令:npm init -y
 *  2. 下载软件包到当前项目,命令:npm i 软件包名称
 *  3. 使用软件包
 */

// 模块名 or 路径?
// 自己写的模块就写路径, 其他情况都是模块名(内置的 / 下载的)
const dayjs = require('dayjs')
    //当前的日期
const res = dayjs().format('YYYY-MM-DD')

console.log(res)

npm - 安装所有依赖 npm i

  1. 当项目中只有 package.json 没有 node_modules
    就执行 npm i 安装所有依赖软件包
  2. 为什么 node_modules 不进行传递: 因为用 npm 下载比磁盘传递要快
javascript 复制代码
/**
 * 目标:安装所有依赖软件包
 * 场景:一般拿到别人的项目后,只有 package.json 缺少 node_modules 时需要做
 * 语法:在当前项目终端下,输入命令:npm i
 * 效果:会根据 package.json 记录的所有包和版本开始下载
 */

// 格式化日期
const dayjs = require('dayjs')
const nowDateStr = dayjs().format('YYYY-MM-DD')
console.log(nowDateStr)

// 求数组里最大值
const _ = require('lodash')
console.log(_.max([1, 2, 8, 3, 4, 5]))

npm - 全局软件包 nodemon

常用命令

功能

|------------------|---------------|
| 功能 | 功能 |
| 执行js 文件 | node xxx |
| 初始化 package.json | npm init -y |
| 下载本地软件包 | npm i 软件包名 |
| 下载全局软件包 | npm i 软件包名 -g |
| 删除软件包 | npm uni 软件包名 |
[ ]

相关推荐
GISer_Jing13 分钟前
前端营销技术实战:数据+AI实战指南
前端·javascript·人工智能
GIS之路32 分钟前
使用命令行工具 ogr2ogr 将 CSV 转换为 Shp 数据(二)
前端
嘉琪0011 小时前
Vue3+JS 高级前端面试题
开发语言·前端·javascript
vipbic2 小时前
用 Turborepo 打造 Strapi 插件开发的极速全栈体验
前端·javascript
天涯学馆2 小时前
为什么 JavaScript 可以单线程却能处理异步?
前端·javascript
Henry_Lau6172 小时前
主流IDE常用快捷键对照
前端·css·ide
陶甜也2 小时前
使用Blender进行现代建筑3D建模:前端开发者的跨界探索
前端·3d·blender
我命由我123452 小时前
VSCode - Prettier 配置格式化的单行长度
开发语言·前端·ide·vscode·前端框架·编辑器·学习方法
HashTang3 小时前
【AI 编程实战】第 4 篇:一次完美 vs 五轮对话 - UnoCSS 配置的正确姿势
前端·uni-app·ai编程
JIngJaneIL3 小时前
基于java + vue校园快递物流管理系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js