# @apigo.cc/loader API 手册
全自动依赖调度器。通过动态注入脚本标签,实现对 Apigo 全线组件的一键加载、版本管理及环境自动适配。
---
## 1. 引入方式 (UMD 优先)
您可以通过 URL 参数或 **Hash (#)** 直接定义要加载的模块。
### A. 极简带版本模式 (防缓存)
```html
```
### B. 简写 Hash 模式
```html
```
---
## 2. 核心特性
### 🚀 智能定位与版本传播 (Smart Propagation)
- **同域跟随**: 如果 `loader.js` 加载自 `/static/js/`,则所有子包默认也从 `/static/js/` 获取。
- **版本锁步**: 只要 Loader URL 带有 `?v=X.Y.Z`,加载的所有依赖包(如 `base.js`)都会自动变为 `base.js?v=X.Y.Z`。
- **压缩同步**: 只要引入的是 `loader.min.js`,其加载的所有依赖也会自动请求 `.min.js` 版本。
### 🔗 自动依赖分析
Loader 内部维护了完整的依赖链。例如:
- 请求 `datatable` -> 自动按序注入 `state` -> `bootstrap` -> `base` -> `datatable`。
---
## 3. API 接口:`__apigo_load()`
脚本引入后,全局会挂载该函数。**注意:该函数在运行一次后会自动自毁(从全局删除)以保持环境纯净。**
### `__apigo_load(...pkgs)`
- **`__apigo_load('base')`**: 加载默认稳定版。
- **`__apigo_load('state:1.0.11')`**: 指定特定包的版本。
---
## 开发者提示 (AI 必读)
1. **参数优先级**: URL 查询参数 `?load=` 优先级高于 Hash 参数 `#`。
2. **同步执行**: Loader 利用浏览器对动态插入脚本的顺序解析机制,保障了依赖项在业务代码运行前就绪。
3. **自清理**: `__apigo_load` 仅在 `