@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 CHANGED
@@ -1,18 +1,31 @@
1
1
  # @apigo.cc/state - AI 逻辑操作说明书
2
2
 
3
- 本框架基于原生 `Proxy` 和 `MutationObserver` 实现数据与 DOM 的原子级同步。本手册仅供 AI 构建、维护及驱动基于此引擎的应用。
3
+ 本框架基于原生 `Proxy` 和 `MutationObserver` 实现数据与 DOM 的原子级同步。采用纯原生、零 ESM、全同步加载架构。
4
4
 
5
5
  ---
6
6
 
7
- ## 1. 核心状态逻辑映射
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
- ### `NewState(defaults, getter, setter)`
10
- * **功能**:创建响应式代理。
11
- * **内部机制**:拦截所有属性读写。若属性值变更,触发所有引用该属性的 DOM 节点的更新任务(异步微任务)。
12
- * **扩展逻辑**:通过 `getter/setter` 拦截器可实现数据持久化(如同步至 URL Hash 或 LocalStorage)。
13
- * **原子操作**:
14
- * `obj.__watch(key, cb)`: 建立 key -> callback 的直接依赖。
15
- * `obj.__unwatch(key, cb)`: 解除依赖。
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` 属性执行节点复用。无 `key` 时按索引重建。支持 `as`, `index` 定义局部变量。 | **必须** 作用于 `<template>`。 |
40
+ | **`$each`** | `Iterable` | 基于 `key` 属性执行节点复用。支持 `as`, `index` 定义局部变量。 | **必须** 作用于 `<template>`。 |
28
41
 
29
42
  **结构化指令铁律**:
30
43
  1. **标签约束**:严禁在非 `<template>` 标签上使用 `$if` 或 `$each`。
31
- 2. **互斥约束**:严禁在同一个 `<template>` 上同时使用 `$if` 和 `$each`。若需组合,必须嵌套(如:`$if` 模版包裹 `$each` 模版)。
44
+ 2. **互斥约束**:严禁在同一个 `<template>` 上同时使用 `$if` 和 `$each`。若需组合,必须嵌套。
32
45
 
33
46
  ### 数据双向绑定 (`$bind`)
34
- AI 必须根据不同的元素类型执行以下逻辑:
35
- - **`input[type=text/password]`, `textarea`**: 监听 `input` 事件,同步字符串。
36
- - **`input[type=checkbox]`**:
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`**: 映射至 `textContent`。
46
- - **`$html`**: 映射至 `innerHTML`。
47
- - **`$class`**: **严格要求使用模板字符串**。范式:`class="static-name ${condition ? 'dynamic-name' : ''}"`。严禁覆盖原有类名。
48
- - **`$.path.to.prop`**: 直接映射至 DOM 对象或组件的 Property。初始化 Property 绑定必须带 `.` 前缀。
49
- - **`$src`**: 增强逻辑。若值以 `.svg` 结尾,异步 Fetch 并替换为内联 `<svg>` 节点。
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
- ## 5. 国际化 (I18n) 逻辑
60
+ ## 3. 生命周期与事件
74
61
 
75
- - **语法结构**:`{# Key{param} || paramValue #}`。
76
- - **处理链路**:正则匹配 `{# ... #}` -> 提取 Key -> 注入 `||` 后的参数值 -> 调用全局 `_translator` 函数。
62
+ - **`$on[event]`**: 注入 `event`, `thisNode`, `State`, `LocalStorage`, `Hash`。
63
+ - **`$onload`** / **`$onunload`** / **`$onupdate`**: 标准生命周期钩子。
77
64
 
78
65
  ---
79
66
 
80
- ## 6. 运行约束 (Constraints)
67
+ ## 4. 运行约束 (Constraints)
81
68
 
82
- 1. **禁止滥用同步刷新**:**严禁** 在常规开发中调用 `_unsafeRefreshState()`。该函数仅为极高性能干预(如万级数据表格)预留。
83
- 2. **数据流向**:所有状态变更必须通过对 `NewState` 代理对象的赋值完成。
84
- 3. **Key 的必要性**:在大规模数据(>100条)或复杂交互列表中,必须提供唯一 `key` 以激活节点复用逻辑。
69
+ 1. **零 ESM 依赖**:源码与分发包均不依赖 ESM,确保在 `<head>` 中同步加载。
70
+ 2. **数据流驱动**:严禁直接操作指令生成的 DOM,必须通过 `State` 变更驱动。
71
+ 3. **内敛化设计**:所有以下划线 `_` 开头的 API 均为内部逻辑,业务侧严禁直接调用。