实践NPM打包和使用

Node.js npm包学习项目

这是我用AI开发的两个工程,用于学习如下npm包管理的知识:

  • 如何创建自己的npm包
  • 如何在项目中安装和使用第三方npm包
  • npm包的生命周期管理

🏗️ 项目结构

复制代码
testpackage/
├── my-npm-library/          # 第一个工程:自制npm包
│   ├── src/
│   │   └── index.ts         # TypeScript源码
│   ├── dist/                # 编译后的JavaScript文件
│   ├── package.json         # npm包配置
│   ├── tsconfig.json        # TypeScript配置
│   └── my-simple-lib-1.0.0.tgz  # 打包后的npm包
└── my-consumer-app/         # 第二个工程:消费者应用
    ├── node_modules/        # 依赖包(包括我们自制的包)
    ├── package.json         # 应用配置
    ├── index.js             # 交互式主程序
    └── demo.js              # 自动化演示脚本

🔧 技术栈

  • 语言: TypeScript + JavaScript
  • 模块化: CommonJS
  • 包管理器: npm
  • 运行时: Node.js

📚 实现的功能

1. 自制npm包 (my-simple-lib)

包含了6个实用的数学函数:

  • add(a, b) - 加法运算
  • subtract(a, b) - 减法运算
  • multiply(a, b) - 乘法运算
  • divide(a, b) - 除法运算(含除零保护)
  • factorial(n) - 阶乘运算(含输入校验)
  • isPrime(num) - 质数判断

2. 消费者应用

  • 交互式CLI界面 - 可以通过菜单选择不同的数学运算
  • 自动化演示脚本 - 一次性运行所有功能的测试
  • 错误处理 - 完善的异常捕获和处理机制

🚀 快速开始

步骤1:构建npm包

bash 复制代码
# 进入npm包项目
cd my-npm-library

# 安装依赖
npm install

# 构建TypeScript代码
npm run build

# 打包成tgz文件
npm pack

步骤2:安装和使用npm包

bash 复制代码
# 进入消费者应用
cd ../my-consumer-app

# 安装我们自制的npm包
npm install ../my-npm-library/my-simple-lib-1.0.0.tgz

# 运行自动化演示
npm run demo

# 或者运行交互式程序
npm start

💡 关键知识点

npm包的核心要素

  1. package.json - 定义了包的元数据、依赖关系和脚本
  2. 入口文件 - main字段指定的主文件
  3. 类型声明 - .d.ts文件提供TypeScript支持

包安装的方式

  1. 本地文件安装 - 适用于开发和调试阶段

    json 复制代码
    "dependencies": {
      "my-simple-lib": "file:../my-npm-library/my-simple-lib-1.0.0.tgz"
    }

模块导出和导入

  • 导出 (library端):使用export关键字暴露函数
  • 导入 (consumer端):使用require()import引入模块
js 复制代码
const mathLib = require('my-simple-lib');

console.log("=== 我的简单数学库演示程序 ===\n");

// 测试加法
console.log("📊 加法运算测试:");
console.log(`5 + 3 = ${mathLib.add(5, 3)}`);
console.log(`-2 + 7 = ${mathLib.add(-2, 7)}`);
console.log();
···
### npm安装包时,不止会下载包,还会下载第三方二进制文件
多年前,安装angular是很容易失败的,就是因为安装angular时,会去其它网站下载一些第三方二进制文件。有些网站国内访问不到,就会安装失败。AI说这些年,国内npm镜像对这些网址做了截获,并把高频第三方二进制放到cdn上,缓解了这个问题。
### npm包是如何下载第三方二进制文件的
我们日常执行nodejs代码时,要么用nodejs xxx.js
要么用 npm run  xxx   --这个xxx就是package.json的scripts中的自定义命令
对于常用的高频命令,比如 start、test等,npm还提供了快捷方式,即可以省略run关键字,直接执行npm start

实际上,npm还预设了preinstall,install,postinstall等命令,这些命令在 npm install时会被自动调用。通过下面的这个例子可以验证这几个命令被调用了。但需要打开打印开关,否则看不到打印信息。
npm install  ../my-npm-library/my-simple-lib-1.0.0.tgz --loglevel verbose
或者npm install  ../my-npm-library/my-simple-lib-1.0.0.tgz --ddd
  "scripts": {
    "build": "tsc",
    "preinstall": "echo '【项目】安装前准备工作...'",
    "install": "echo '【项目】安装中...'",
    "postinstall": "echo '【项目】安装后工作,如构建资产...'",
    "prepack": "npm run build"
  },
相关推荐
玩嵌入式的菜鸡34 分钟前
网页访问单片机设备---基于mqtt
前端·javascript·css
前端一小卒1 小时前
我用 Claude Code 的 Superpowers 技能链写了个服务,部署前差点把服务器搞炸
前端·javascript·后端
滑雪的企鹅.2 小时前
HTML头部元信息避坑指南大纲
前端·html
一拳不是超人2 小时前
老婆天天吵吵要买塔罗牌,我直接用 AI 2 小时写了个在线塔罗牌
前端·ai编程
excel4 小时前
如何解决 Nuxt DevTools 中关于 unstorage 包的报错
前端
Rust研习社4 小时前
使用 Axum 构建高性能异步 Web 服务
开发语言·前端·网络·后端·http·rust
C澒4 小时前
AI 生码 - API2Code:接口智能匹配与 API 自动化生码全链路设计
前端·低代码·ai编程
浔川python社4 小时前
HTML头部元信息避坑指南技术文章大纲
前端·html
IT_陈寒5 小时前
SpringBoot配置加载顺序把我坑惨了
前端·人工智能·后端
kyriewen5 小时前
Next.js部署:从本地跑得欢,到线上飞得稳
前端·react.js·next.js