275 lines
5.6 KiB
Markdown
275 lines
5.6 KiB
Markdown
|
|
# 开发和项目说明
|
|||
|
|
|
|||
|
|
## 快速开始
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
# 安装依赖
|
|||
|
|
npm install
|
|||
|
|
|
|||
|
|
# 开发模式(Web)
|
|||
|
|
npm run dev
|
|||
|
|
|
|||
|
|
# 构建(Web)
|
|||
|
|
npm run build
|
|||
|
|
|
|||
|
|
# 预览构建结果
|
|||
|
|
npm run preview
|
|||
|
|
|
|||
|
|
# CLI 开发模式
|
|||
|
|
npm run cli:dev
|
|||
|
|
|
|||
|
|
# CLI 构建
|
|||
|
|
npm run cli:build
|
|||
|
|
|
|||
|
|
# 运行测试
|
|||
|
|
npm test
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 项目结构
|
|||
|
|
|
|||
|
|
```
|
|||
|
|
ttrpg-tools/
|
|||
|
|
├── src/
|
|||
|
|
│ ├── cli/ # CLI 工具源码
|
|||
|
|
│ │ ├── commands/ # 命令实现 (serve, compile)
|
|||
|
|
│ │ ├── index.ts # CLI 入口
|
|||
|
|
│ │ └── types.ts # 类型定义
|
|||
|
|
│ ├── components/ # TTRPG 组件
|
|||
|
|
│ │ ├── md-dice.tsx # 骰子组件
|
|||
|
|
│ │ ├── md-table.tsx # 表格组件
|
|||
|
|
│ │ ├── md-deck/ # 卡牌组件
|
|||
|
|
│ │ ├── md-pins.tsx # 标记组件
|
|||
|
|
│ │ ├── md-commander/ # 命令追踪器
|
|||
|
|
│ │ ├── md-yarn-spinner.tsx # 叙事线组件
|
|||
|
|
│ │ ├── md-token.tsx # 代币组件
|
|||
|
|
│ │ ├── Article.tsx # 文章组件
|
|||
|
|
│ │ ├── Sidebar.tsx # 侧边栏
|
|||
|
|
│ │ ├── FileTree.tsx # 文件树
|
|||
|
|
│ │ └── utils/ # 工具函数
|
|||
|
|
│ ├── markdown/ # Markdown 解析器
|
|||
|
|
│ │ ├── index.ts # marked 配置
|
|||
|
|
│ │ └── mermaid.ts # mermaid 支持
|
|||
|
|
│ ├── data-loader/ # 数据加载器
|
|||
|
|
│ ├── plotcutter/ # 剧情切割工具
|
|||
|
|
│ ├── yarn-spinner/ # 叙事线解析
|
|||
|
|
│ ├── App.tsx # 主应用
|
|||
|
|
│ ├── main.tsx # 入口文件
|
|||
|
|
│ ├── styles.css # 样式
|
|||
|
|
│ ├── index.html # HTML 模板
|
|||
|
|
│ └── global.d.ts # 类型声明
|
|||
|
|
├── bin/
|
|||
|
|
│ └── cli/ # CLI 二进制文件
|
|||
|
|
├── content/ # 示例内容
|
|||
|
|
├── docs/ # 文档
|
|||
|
|
├── package.json
|
|||
|
|
├── tsconfig.json
|
|||
|
|
├── tsconfig.cli.json
|
|||
|
|
├── rsbuild.config.ts
|
|||
|
|
└── jest.config.js
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 技术栈
|
|||
|
|
|
|||
|
|
| 类别 | 技术 |
|
|||
|
|
|------|------|
|
|||
|
|
| 前端框架 | Solid.js 1.9+ |
|
|||
|
|
| 构建工具 | Rsbuild |
|
|||
|
|
| 样式 | Tailwind CSS 4 + @tailwindcss/typography |
|
|||
|
|
| Markdown | marked + marked-directive + marked-alert + marked-gfm-heading-id |
|
|||
|
|
| 图表 | mermaid |
|
|||
|
|
| 3D | three.js |
|
|||
|
|
| 测试 | Jest |
|
|||
|
|
| CLI | commander + chokidar |
|
|||
|
|
|
|||
|
|
## 开发规范
|
|||
|
|
|
|||
|
|
### Solid.js 最佳实践
|
|||
|
|
|
|||
|
|
- **优先使用 `createEffect` 和 `createMemo`** 实现响应式
|
|||
|
|
- 在 JSX 中直接引用 `props` 保持响应式
|
|||
|
|
- 避免滥用 `onMount` + `createSignal`
|
|||
|
|
|
|||
|
|
```tsx
|
|||
|
|
// ✅ 推荐
|
|||
|
|
const doubled = createMemo(() => count() * 2);
|
|||
|
|
createEffect(() => console.log(count()));
|
|||
|
|
|
|||
|
|
// ❌ 避免
|
|||
|
|
onMount(() => {
|
|||
|
|
const [value, setValue] = createSignal(0);
|
|||
|
|
});
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 组件开发
|
|||
|
|
|
|||
|
|
- **不使用 Shadow DOM**:使用 `noShadowDOM()`
|
|||
|
|
- **继承 Tailwind CSS 样式系统**
|
|||
|
|
- 使用 `customElement` 注册自定义元素
|
|||
|
|
|
|||
|
|
```tsx
|
|||
|
|
import { customElement, noShadowDOM } from "solid-element";
|
|||
|
|
|
|||
|
|
customElement("md-dice", { key: "" }, (props, { element }) => {
|
|||
|
|
noShadowDOM();
|
|||
|
|
// 组件逻辑
|
|||
|
|
});
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 类型检查
|
|||
|
|
|
|||
|
|
开发完成后检查类型错误:
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
npx tsc --noEmit
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 代码风格
|
|||
|
|
|
|||
|
|
- 使用 TypeScript 严格模式
|
|||
|
|
- 遵循 ESLint 配置(如有)
|
|||
|
|
- 使用 2 空格缩进
|
|||
|
|
|
|||
|
|
## 添加新组件
|
|||
|
|
|
|||
|
|
### 1. 创建组件文件
|
|||
|
|
|
|||
|
|
```tsx
|
|||
|
|
// src/components/md-new-component.tsx
|
|||
|
|
import { customElement, noShadowDOM } from "solid-element";
|
|||
|
|
import { createSignal } from "solid-js";
|
|||
|
|
|
|||
|
|
export interface NewComponentProps {
|
|||
|
|
prop1?: string;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
customElement("md-new-component", { prop1: "" }, (props, { element }) => {
|
|||
|
|
noShadowDOM();
|
|||
|
|
|
|||
|
|
const [state, setState] = createSignal("");
|
|||
|
|
|
|||
|
|
return (
|
|||
|
|
<div class="new-component">
|
|||
|
|
{/* 组件内容 */}
|
|||
|
|
</div>
|
|||
|
|
);
|
|||
|
|
});
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 2. 注册组件
|
|||
|
|
|
|||
|
|
```tsx
|
|||
|
|
// src/components/index.ts
|
|||
|
|
import './md-new-component';
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 3. 导出类型(可选)
|
|||
|
|
|
|||
|
|
```tsx
|
|||
|
|
// src/components/index.ts
|
|||
|
|
export type { NewComponentProps } from './md-new-component';
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 构建配置
|
|||
|
|
|
|||
|
|
### Rsbuild 配置
|
|||
|
|
|
|||
|
|
```ts
|
|||
|
|
// rsbuild.config.ts
|
|||
|
|
import { defineConfig } from '@rsbuild/core';
|
|||
|
|
import { pluginBabel } from '@rsbuild/plugin-babel';
|
|||
|
|
import { pluginSolid } from '@rsbuild/plugin-solid';
|
|||
|
|
import tailwindcss from '@tailwindcss/postcss';
|
|||
|
|
|
|||
|
|
export default defineConfig({
|
|||
|
|
plugins: [pluginBabel(), pluginSolid()],
|
|||
|
|
tools: {
|
|||
|
|
postcss: {
|
|||
|
|
postcssOptions: {
|
|||
|
|
plugins: [tailwindcss()],
|
|||
|
|
},
|
|||
|
|
},
|
|||
|
|
},
|
|||
|
|
html: {
|
|||
|
|
template: './src/index.html',
|
|||
|
|
},
|
|||
|
|
});
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### TypeScript 配置
|
|||
|
|
|
|||
|
|
- `tsconfig.json` - 主项目配置(Web)
|
|||
|
|
- `tsconfig.cli.json` - CLI 工具配置(Node.js)
|
|||
|
|
|
|||
|
|
## 测试
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
# 运行所有测试
|
|||
|
|
npm test
|
|||
|
|
|
|||
|
|
# 运行特定测试文件
|
|||
|
|
npm test -- src/components/md-dice.test.ts
|
|||
|
|
|
|||
|
|
# 监听模式
|
|||
|
|
npm test -- --watch
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 调试
|
|||
|
|
|
|||
|
|
### Web 开发
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
npm run dev
|
|||
|
|
# 访问 http://localhost:3000
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### CLI 调试
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
# 使用 ts-node 直接运行
|
|||
|
|
npm run ttrpg serve ./content
|
|||
|
|
|
|||
|
|
# 或构建后运行
|
|||
|
|
npm run cli:build
|
|||
|
|
node dist/cli/index.js serve ./content
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 发布流程
|
|||
|
|
|
|||
|
|
1. 更新版本号
|
|||
|
|
2. 运行测试和类型检查
|
|||
|
|
3. 构建 Web 和 CLI
|
|||
|
|
4. 发布到 npm
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
npm run build
|
|||
|
|
npm run cli:build
|
|||
|
|
npm test
|
|||
|
|
npx tsc --noEmit
|
|||
|
|
npm publish
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
## 常见问题
|
|||
|
|
|
|||
|
|
### Windows 换行符
|
|||
|
|
|
|||
|
|
开发环境主要在 Windows 上,注意使用 CRLF 换行符。
|
|||
|
|
|
|||
|
|
### 依赖安装失败
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
# 清理缓存
|
|||
|
|
npm cache clean --force
|
|||
|
|
rm -rf node_modules package-lock.json
|
|||
|
|
npm install
|
|||
|
|
```
|
|||
|
|
|
|||
|
|
### 构建错误
|
|||
|
|
|
|||
|
|
```bash
|
|||
|
|
# 检查类型
|
|||
|
|
npx tsc --noEmit
|
|||
|
|
|
|||
|
|
# 重新构建
|
|||
|
|
npm run build
|
|||
|
|
```
|