使用PNPM管理单一仓库

简介

以前用过yarn+lerna管理单一仓库,实际使用中还是存在不少问题,pnpm出来以后除了对node_modules管理非常好以为,对workspace支持也非常好。本项目就是使用fatherdumipnpm技术栈的React组件单一仓库模板。

使用这个项目模板根据下面的说明文档,可以非常快速的完成创建包、编写和展示组件文档、构建和发布到npm仓库。

仓库地址:scfido/pnpm-monorepo: 使用father、dumi、pnpm技术栈的React组件单一仓库模板。 (github.com)

使用

安装依赖

在根目录执行会自动安装所有项目的依赖包。

pnpm install

清理所有依赖

pnpm clean

清理所有依赖并重新安装

pnpm reinstall

启动文档项目

文档项目有两个作用:

  1. 介绍组件的使用方法
  2. 组件的功能演示
pnpm start

开发

创建新包

在这个模板中新添加一个包,操作流程如下,以创建liba为例:

cd .\packages\
mkdir liba
cd liba
pnpm dlx create-father ./ 

# 根据提示选择或输入你的信息。
# √ Pick target platform(s) » Browser
# √ Pick NPM client » pnpm
# √ Input NPM package name ... liba
# √ Input NPM package description ...
# √ Input NPM package author (Name <email@example.com>) ...

包目录创建好后,添加react组件之前要对项目参数做一些简单的配置。

.\packages\liba\tsconfig.json,的compilerOptions中增加jsxesModuleInteropsourceMap三项参数。

{
  "compilerOptions": {
    "strict": true,
    "declaration": true,
    "skipLibCheck": true,
    "baseUrl": "./",
    "jsx": "react",
    "esModuleInterop": true,
    "sourceMap": true
  }
}

然后添加你要开发的组件依赖包

# 添加依赖包react
pnpm add react

添加组件文件.\packages\liba\src\Button.tsx

// .\packages\liba\src\Button.tsx

import React from "react";

export default ()=>{
    return(<button>From lib a</button>)
}

导出组件

// .\packages\liba\src\index.ts

export {default as ButtonA}  from "./Button"

生成

cd .\packages\liba
pnpm build

生成成功后会在.\packages\liba\dist\esm中看到结果。

在文档中展示组件

前面已经创建好了包liba,并创建了组件ButtonA,下面在文档中展示这个组件。

.\packages\docs包中,添加liba的应用。

 // .\packages\docs\package.json

 "dependencies": {
    // 添加liba的依赖,注意版本号的写法。
    "liba": "workspace:^1.0.0"
    // ... 其它依赖
 }

在创建.\packages\docs\src\libA的目录,并新建展示文档index.md

# .\packages\docs\src\libA\index.md
---
nav:
  title: Components
  path: /components
---

## Libiary A

Button A:

```tsx
import React from 'react';
import {ButtonA} from "liba";

export default () => {
  return(
    <div>
    <ButtonA/>
    </div>
  )
};

```

启动文档项目就能看到liba中的组件展示了。

pnpm start

热更新

组件展示文档项目运行起来后,文档自身的修改是能够热更新的,但是引用的liba包中的组件并不能热更新,修改了组件内容后,需要在组件目录运行pnpm build才能生效。要实现组件的热更新,可以在组件包目录中使用pnpm dev来监视文件变更并自动build

cd .\packages\liba
pnpm dev

发布

发布分为发布说明文档和组件两种情况。

发布文档

将文档发布成网站。

pnpm docs:build --filter docs

输出目录在packages\docs\docs-dist,这些文件放在web服务中就可以访问。例如使用dotnet-serve工具。

# 安装dotnet-serve
dotnet tool install --global dotnet-serve

# 启动网站
cd c
dotnet serve -o

发布组件

发布组件非常简单,和npm的操作流程一致。在根目录下执行pnpm publish即可。通过npmjs.org用户注册等一系列操作发布成功。完成后发现并不是我们要的结果,这样是把整个项目作为单个包发布出去了。而我们想要的是发布这三个包。

  • @pnpm-monorepo/liba
  • @pnpm-monorepo/libb
  • @pnpm-monorepo/libc

其实也非常简单,使用filter参数过滤项目,或者分别到各自的目录下去发布就可以了。

# 使用指定项目名称的方式
pnpm --filter liba publish 
pnpm --filter libb publish 
pnpm --filter libc publish

# 使用通配符过滤的方式,注意windows下不要单引号。
pnpm --filter 'lib*' publish

# 进入到项目目录下发布的方式
cd  .\packages\liba
pnpm publish

cd ..\libb
pnpm publish

cd ..\libc
pnpm publish

或者使用script目录下的publish.ps1脚本。

统一包版本

如果希望发布的所有包版本统一,可使用以下命令。脚本会自动把packages目录下的项目设置为指定版本号,并且会自动添加添加git tag。

./set-version.ps1 1.1.4

引用包

包开发完成后就是给其它项目使用了,按上面的步骤发布到npm仓库后,按常规操作用名称引用即可。

但是在开发过程中要引用本地包怎么操作呢?分仓库内和仓库外两种引用情况。

仓库内

在同一仓库内引用,比如docs项目引用liba。只需要在docs项目中执行添加包命令,并加上-w``--workspace参数,表面是引用workspace中的包。

# 中项目根目录操作需要带过滤条件
pnpm add liba -w --filter docs

# 进入包的目录可以直接添加
cd .\packages\docs
pnpm add liba -w

仓库外

开发时其它仓库需要引用本项目的包时,可使用pnpm的link命令。

  1. 在被引用的仓库执行
# 例如liba是要被引用的库,将liba注册到全局仓库
cd .\packages\liba
pnpm link . --global
  1. 在引用的仓库执行
# 从全局仓库连接 liba
pnpm link liba --global

注意:连接后会在package.jsondependencies中添加liba。如果你的包从来没有发布过,以后执行install的时候会因为找不到这个包而失败。

常见问题

ANTD组件没有加载CSS

在docs项目中引用ANTD组件,并在文档中增加样式引用。

import React from 'react';
import {Button} from "libb";
import 'antd/dist/antd.css';

export default () => {
  return(
    <div>
    <Button/>
    </div>
  )
};

包修改以后不生效

我发现包减少输出文件引用包的node_modules下仍然存在的情况,建议全部删除后重新安装。

pnpm reinstall

报找不到引用包的文件

docs项目生成报找不到引用包的文件,并且错误信息中的文件位置在docs/src目录下,这是因为引用包编译失败,没有输出到docs的node_modules中,因为docs在tsconfig.josn中重定义了@/*:["src/*"],所以不要被编译错误中的文件位置误导了。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,928评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,192评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,468评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,186评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,295评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,374评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,403评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,186评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,610评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,906评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,075评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,755评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,393评论 3 320
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,079评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,313评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,934评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,963评论 2 351

推荐阅读更多精彩内容