当前位置: 首页 > article >正文

npm pack使用

npm pack 的作用主要是从包中创建一个压缩文件(tarball),通常具有.tgz扩展名,包含了打包的模块及其依赖,可用于分发或部署。其应用场景包括私有库或组件的分发、离线环境的依赖安装、CI/CD 自动化构建等

在使用npm管理第三方模块时,这些模块会被安装在 node_modules 目录下。当我们需要把某些模块给其他小伙伴或者搭建npm私服时,需要将node_modules 的所有模块生成N个packname-version.tgz文件,方便其他人员使用npm install packname-version.tgz命令安装

执行npm pack命令时,npm会根据模块的package.json文件,将模块及其依赖打包成一个.tgz(压缩的tar文件)格式的文件。此文件可以在其他项目中作为依赖使用,或者上传到注册表供他人下载和使用。如果不提供任何参数运行npm pack,则默认打包当前目录中的模块。简单说就是进入需要打成 .tgz 的包目录中执行npm pack命令,就可生成该包对应的.tgz压缩文件。

当然我们可以手动进入某个目录执行npm pack命令来使用。也可以自动的进行打包,nodejs中有提供对应的模块及方法,下面来个示例:

1. 随便建个文件夹,我这里叫npm-package

2. 执行npm init -y

3. 创建index.js文件

index.js

const path = require('path')
const fs = require('fs')
const { execSync } = require('child_process')

// 先判断根目录是否有packages文件夹(用于存放.tgz包),如果没有则创建
const packageDir = path.join(__dirname, './packages')
if(!fs.existsSync(packageDir)) {
  fs.mkdirSync(packageDir)
}

// node_modules 路径
const nodeModulesDir = path.join(__dirname, './node_modules')

// 过滤掉以 “.”、“@”开头的包
const modules = fs.readdirSync(nodeModulesDir).filter(name => !name.startsWith('.') && !name.startsWith('@'))

for(let name of modules) {
  // 有的包执行npm pack可能会报错(具体原因暂未深入探索,真正用到再补充),所以采用try catch
  try {
    const targetDir = path.join(nodeModulesDir, name)
    // 执行npm pack命令
    execSync('npm pack', { cwd: targetDir })
    // 从该包中找出.tgz
    const tgz = fs.readdirSync(targetDir).find(item => item.endsWith('.tgz'))
    if(tgz) {
      // 移动.tgz压缩包文件到根目录packages 名称修改为包名
      fs.renameSync(path.join(targetDir, tgz), path.join(packageDir, `${name}.tgz`))
    }
  } catch {}
}

4. 修改根目录package.json

修改package.json中的scripts,增加postinstall脚本(postinstall会在npm install 执行完后自动执行该脚本),如下:

5. 虽然安装几个包试试

我这里随便装个我自己的包(wft-util)和element-ui、html2canvas吧

// 先安装需要的包
npm i wft-utils element-ui html2canvas

// 然后再执行 npm install (否则postinstall 不会触发) or 或者手动执行node ./index.js也行
npm install

6. 效果如下:

大家可以看到在根目录自动创建了packages目录 并自动将node_modules中的依赖包打成.tgz的包并移动到packages中。packages这个包就是我们所需要的。我们可以将该包放在自己公司私服上或者其他操作都行,它是可以npm install供我们使用。


http://www.kler.cn/a/282479.html

相关文章:

  • 六、volatile
  • Spark RDD sortBy算子什么情况会触发shuffle
  • Python学习------第八天
  • 字节青训-小M的多任务下载器挑战、版本号比较
  • Fish Agent V0.13B:Fish Audio的语音处理新突破,AI语音助手的未来已来!
  • hive 统计各项目下排名前5的问题种类
  • 计算机基础知识复习8.29
  • 深度学习--复制机制
  • 深度学习——LLM大模型分词
  • MySQL编译安装
  • Linux:NAT等相关问题
  • 微信小程序利用canva进行大图片压缩
  • 对标GPT4o,智谱推出新一代基座大模型 GLM-4-Plus
  • Python反向传播导图
  • 如何通过日志或gv$sql_audit,分析OceanBase运行时的异常SQL
  • 如何理解进程
  • 渲染引擎实践 - UnrealEngine引擎中启用 Vulkan 和使用 Renderdoc 抓帧
  • Nginx SSL密码短语配置指南:增强负载均衡安全性
  • 王立铭脑科学50讲:49,灵魂和肉体,灵魂离体的感觉是怎么回事
  • ceph-rgw zipper的设计理念(2)
  • 工程师 - RS232通讯介绍
  • KTH5701 系列低功耗、高精度 3D 霍尔传感器
  • 命令模式详解
  • Oracle 11g RAC to 11g RAC ADG部署搭建
  • [M模拟] lc3153. 所有数对中数位不同之和(模拟+按位统计)
  • 问:介绍一下Java中的深克隆浅克隆?