@apigo.cc/state 1.0.16 → 1.0.19
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +39 -52
- package/dist/state.js +637 -618
- package/dist/state.min.js +1 -1
- package/package.json +1 -1
package/README.md
CHANGED
|
@@ -1,18 +1,31 @@
|
|
|
1
1
|
# @apigo.cc/state - AI 逻辑操作说明书
|
|
2
2
|
|
|
3
|
-
本框架基于原生 `Proxy` 和 `MutationObserver` 实现数据与 DOM
|
|
3
|
+
本框架基于原生 `Proxy` 和 `MutationObserver` 实现数据与 DOM 的原子级同步。采用纯原生、零 ESM、全同步加载架构。
|
|
4
4
|
|
|
5
5
|
---
|
|
6
6
|
|
|
7
|
-
##
|
|
7
|
+
## 0. 快速开始 (Quick Start)
|
|
8
|
+
直接在 HTML 中引入(无需打包,完全非 ESM 注入):
|
|
9
|
+
```html
|
|
10
|
+
<script src="https://cdn.jsdelivr.net/npm/@apigo.cc/state@1.0.19/dist/state.min.js"></script>
|
|
11
|
+
```
|
|
8
12
|
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
13
|
+
---
|
|
14
|
+
|
|
15
|
+
## 1. 核心全局 API
|
|
16
|
+
|
|
17
|
+
引入后,以下接口直接挂载至 `globalThis`:
|
|
18
|
+
|
|
19
|
+
| API | 功能说明 |
|
|
20
|
+
| :--- | :--- |
|
|
21
|
+
| **`NewState(defaults, getter, setter)`** | 创建响应式状态代理对象。 |
|
|
22
|
+
| **`Component.register(name, setup, tpl)`** | 注册自定义组件。支持自动模板合并。 |
|
|
23
|
+
| **`RefreshState(node)`** | (别名 `_unsafeRefreshState`) 手动触发特定树的扫描。仅限极致性能调优。 |
|
|
24
|
+
| **`SetTranslator(fn)`** | 设置国际化翻译函数。 |
|
|
25
|
+
| **`$` / `$$`** | 增强型原生选择器(支持限定作用域)。 |
|
|
26
|
+
| **`Util`** | 常用工具集(`clone`, `makeDom`, `getFunctionBody` 等)。 |
|
|
27
|
+
| **`Hash` / `LocalStorage`** | 自动同步至 URL 或本地存储的响应式单例。 |
|
|
28
|
+
| **`State`** | 框架内置的全局持久化状态单例(含 `exitBlocks` 等控制位)。 |
|
|
16
29
|
|
|
17
30
|
---
|
|
18
31
|
|
|
@@ -24,61 +37,35 @@
|
|
|
24
37
|
| 指令 | 触发逻辑 | DOM 行为 | 运行约束 |
|
|
25
38
|
| :--- | :--- | :--- | :--- |
|
|
26
39
|
| **`$if`** | `Boolean(result)` | `true`: 挂载节点; `false`: 移除节点。 | **必须** 作用于 `<template>`。 |
|
|
27
|
-
| **`$each`** | `Iterable` | 基于 `key`
|
|
40
|
+
| **`$each`** | `Iterable` | 基于 `key` 属性执行节点复用。支持 `as`, `index` 定义局部变量。 | **必须** 作用于 `<template>`。 |
|
|
28
41
|
|
|
29
42
|
**结构化指令铁律**:
|
|
30
43
|
1. **标签约束**:严禁在非 `<template>` 标签上使用 `$if` 或 `$each`。
|
|
31
|
-
2. **互斥约束**:严禁在同一个 `<template>` 上同时使用 `$if` 和 `$each
|
|
44
|
+
2. **互斥约束**:严禁在同一个 `<template>` 上同时使用 `$if` 和 `$each`。若需组合,必须嵌套。
|
|
32
45
|
|
|
33
46
|
### 数据双向绑定 (`$bind`)
|
|
34
|
-
|
|
35
|
-
- **`
|
|
36
|
-
- **`
|
|
37
|
-
- 绑定值为 `Array`: 若选中,`push(value)`(去重);若取消,`splice(index, 1)`。
|
|
38
|
-
- 绑定值为非 `Array`: 同步 `checked` 为 `true/false`。
|
|
39
|
-
- **`input[type=radio]`**: 选中项 `value === 绑定值` 时设置 `checked` 为 `true`。
|
|
40
|
-
- **`select`**: 同步选中项的 `value`。
|
|
41
|
-
- **`[contenteditable]`**: 监听 `input`,同步 `innerHTML`。
|
|
42
|
-
- **`input[type=file]`**: 同步 `files` 对象。
|
|
47
|
+
- **`input`, `textarea`, `select`**: 自动监听 `input/change` 事件。
|
|
48
|
+
- **`checkbox`**: 支持数组模式(多选)和布尔模式。
|
|
49
|
+
- **`[contenteditable]`**: 支持。
|
|
43
50
|
|
|
44
51
|
### 属性与 Property 绑定
|
|
45
|
-
- **`$text`**:
|
|
46
|
-
- **`$
|
|
47
|
-
-
|
|
48
|
-
-
|
|
49
|
-
-
|
|
50
|
-
- **`$$attr`**: 二级求值。`eval(eval(expr))` 逻辑,用于动态生成指令代码。
|
|
51
|
-
|
|
52
|
-
---
|
|
53
|
-
|
|
54
|
-
## 3. 生命周期与事件逻辑
|
|
55
|
-
|
|
56
|
-
- **`$on[event]`**: 映射为 `addEventListener`。注入 `event`, `thisNode`, `State`, `LocalStorage`, `Hash`。
|
|
57
|
-
- **生命周期**:
|
|
58
|
-
- **`$onload`**: 节点进入 DOM 且指令解析完成后触发。
|
|
59
|
-
- **`$onunload`**: 节点从 DOM 移除前触发。
|
|
60
|
-
- **`$onupdate`**: 绑定的数据变更且渲染任务完成后执行。
|
|
61
|
-
|
|
62
|
-
---
|
|
63
|
-
|
|
64
|
-
## 4. 组件上下文逻辑
|
|
65
|
-
|
|
66
|
-
- **初始化**:`Component.register(tagName, setupFn)`。
|
|
67
|
-
- **作用域隔离**:每个组件持有独立 `state`。
|
|
68
|
-
- **穿透访问**:通过 `this.parent` 访问父级作用域链。
|
|
69
|
-
- **插槽映射**:`slot="name"` (声明) -> `slot-id="name"` (宿主)。
|
|
52
|
+
- **`$text`** / **`$html`**: 映射内容。
|
|
53
|
+
- **`$class`**: **严格要求使用模板字符串**。范式:`class="static ${expr}"`。
|
|
54
|
+
- **`$.path.to.prop`**: 映射 DOM 对象或组件的 Property。
|
|
55
|
+
- **`$src`**: 增强 SVG 内联逻辑。
|
|
56
|
+
- **`$$attr`**: 二级求值(Dynamic Directives)。
|
|
70
57
|
|
|
71
58
|
---
|
|
72
59
|
|
|
73
|
-
##
|
|
60
|
+
## 3. 生命周期与事件
|
|
74
61
|
|
|
75
|
-
-
|
|
76
|
-
-
|
|
62
|
+
- **`$on[event]`**: 注入 `event`, `thisNode`, `State`, `LocalStorage`, `Hash`。
|
|
63
|
+
- **`$onload`** / **`$onunload`** / **`$onupdate`**: 标准生命周期钩子。
|
|
77
64
|
|
|
78
65
|
---
|
|
79
66
|
|
|
80
|
-
##
|
|
67
|
+
## 4. 运行约束 (Constraints)
|
|
81
68
|
|
|
82
|
-
1.
|
|
83
|
-
2.
|
|
84
|
-
3.
|
|
69
|
+
1. **零 ESM 依赖**:源码与分发包均不依赖 ESM,确保在 `<head>` 中同步加载。
|
|
70
|
+
2. **数据流驱动**:严禁直接操作指令生成的 DOM,必须通过 `State` 变更驱动。
|
|
71
|
+
3. **内敛化设计**:所有以下划线 `_` 开头的 API 均为内部逻辑,业务侧严禁直接调用。
|