# san-html-cases **Repository Path**: mirrors_ecomfe/san-html-cases ## Basic Information - **Project Name**: san-html-cases - **Description**: No description available - **Primary Language**: Unknown - **License**: Not specified - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2020-08-08 - **Last Updated**: 2026-02-21 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # San HTML 样例 本仓库维护 San 在不同的使用场景下正确的 HTML 是什么。即 [san-ssr][san-ssr] 应当产出怎样的 HTML,以及 [san 核心][san] 正确反解依赖怎样的 HTML。因此本仓库就是 San HTML 的规范,并由 san 和 san-ssr 两个仓库的 e2e 测试来确保有效。 本仓库的用途包括: 1. [san][san] 核心中的 e2e case 使用本仓库提供的 component, HTML 和 spec(浏览器端运行)。 2. [san-ssr][san-ssr] 中的 e2e case 使用本仓库提供的 component 和 HTML。 3. [san-ssr-target-php][san-ssr-target-php] 中的 e2e case 使用本仓库提供的 component 和 HTML。 ## 目录结构 src 下每个目录表示一个测试样例,每个测试样例包含如下文件: - spec.js 是 san e2e 测试的代码片段,因此不要尝试 Lint。 - data.json 是 SSR 使用的数据,为可移植尽量使用 json,其他情况(比如 `Date`)使用 date.js、date.php。 - component.js 是组件源代码,SSR 和反解公用。 - component.ts 用来维护 TypeScript 样例,SSR 尤其是 san-ssr-target-php 使用。它是静态分析的,因此有更多要求: - template 必须是 String Literal 或 NoSubstitutionTemplateLiteral。 - 宿主 API 受限,比如 Date API 是 [Ts2Php][ts2php] Date 定义的功能子集。 ## 特殊标记 - spec.js 中的注释标记(比如 `// inject`)用来生成 e2e 测试代码,不可删除。 - -ndo 命名的 case 表示渲染参数 noDataOutput 为 true。 - -so 命名的 case 表示编译参数 ssrOnly 为 true。 [san]: https://github.com/baidu/san [san-ssr]: https://github.com/baidu/san-ssr [san-ssr-target-php]: https://github.com/searchfe/san-ssr-target-php [ts2php]: https://github.com/searchfe/ts2php