npm pack 一键构建npm离线包

npm pack 命令

npm pack 命令是 npm 包管理器的核心功能之一,专门用于生成离线 npm 模块或依赖包。它的工作原理十分简单:它会遍历 node_modules 目录,查找所有 package.json 文件,并执行 npm pack 命令生成压缩文件。这些压缩文件包含了模块及其所有依赖项,可以独立于 npm 仓库进行安装和使用。

my-app/scripts

build.sh文件

shell 复制代码
set -e  # 遇到错误立即退出

curDir=$(readlink -f "$(dirname "$0")")

cd $curDir/../

echo "📦 安装依赖..."

yarn

echo "🔨 开始构建..."

yarn build

echo "✅ 构建完成!"

这几行代码是一个项目构建自动化脚本,它的核心作用是:

  1. 智能定位:自动找到脚本所在的准确位置
  2. 目录切换:确保在正确的项目根目录下执行
  3. 依赖管理:自动安装项目所需的所有依赖
  4. 构建执行:运行项目的构建流程

pack.sh 文件

shell 复制代码
#!/bin/bash

# 错误时立即退出
set -e

# 获取脚本所在目录的绝对路径
curDir=$(readlink -f "$(dirname "$0")")

echo "🚀 开始打包流程..."
echo "当前脚本目录: $curDir"

# 1. 重新编译项目
echo "🔄 重新编译项目..."
sh $curDir/build.sh

# 2. 更新版本号为预发布版本
echo "📦 更新版本号..."
npm version prerelease --preid=alpha --no-git-tag-version
current_version=$(node -p "require('$curDir/../package.json').version")
echo "新版本号: $current_version"

# 3. 复制 package.json 到 dist 目录
echo "📁 复制 package.json..."
cp $curDir/../package.json $curDir/../dist/

# 4. 进入 dist 目录
cd $curDir/../dist
echo "切换到目录: $(pwd)"

# 5. 修改版本号,添加本地时间戳
echo "⏰ 添加本地时间戳..."
timestamp=$(date +%Y%m%d%H%M%S)
echo "时间戳: $timestamp"

# 修正 sed 命令,正确的正则表达式
sed -i "s/\"version\": \".*-alpha\.[0-9]*\"/&.local.$timestamp/" package.json

# 验证修改结果
final_version=$(node -p "require('./package.json').version")
echo "最终版本号: $final_version"

# 6. 打包
echo "📦 开始打包..."
npm pack

# 显示生成的文件
echo "✅ 打包完成!生成文件:"
ls -la *.tgz

pubilsh.sh文件

相关推荐
天若有情67314 小时前
XiangJsonCraft v1.2.0重大更新解读:本地配置优先+全量容错,JSON解耦开发体验再升级
前端·javascript·npm·json·xiangjsoncraft
有个人神神叨叨17 小时前
pnpm cnpm npm 对比
前端·arcgis·npm
有个人神神叨叨19 小时前
node、npm 和 npx 的关系
前端·arcgis·npm
虹科网络安全2 天前
艾体宝新闻 | NPM 生态系统陷入困境:自我传播恶意软件在大规模供应链攻击中感染了 187 个软件包
前端·npm·node.js
摇滚侠2 天前
PNPM 包管理工具和 NPM 包管理工具
vscode·npm·node.js·pnpm
147API2 天前
改名后的24小时:npm 包抢注如何劫持开源项目供应链
前端·npm·node.js
抵梦2 天前
NPM、CNPM、PNPM:Node.js 依赖工具对比与选择
前端·npm·node.js
摇滚侠2 天前
npm 设置了阿里云镜像,然后全局安装了 pnpm,pnpm 还需要设置阿里云镜像吗
前端·阿里云·npm
-凌凌漆-3 天前
vscode运行npm报错,npm : 无法加载文件 xxxxx/npm.ps1,因为在此系统上禁止运行脚本。
ide·vscode·npm
*小雪5 天前
nvm的安装与管理和npm audit的报错解决
前端·npm·node.js