Generates correct app.json, page config, and project.config.json for Skyline projects, handling renderer choice, navigation style, and glass-easel component framework setup.
Best for: Engineers building or migrating to Skyline mini-programs who need config boilerplate fast.
---
name: skyline-config
description: Skyline 小程序 JSON 配置规范技能。涵盖 app.json 全局配置(renderer、rendererOptions、componentFramework)、页面 json 配置(navigationStyle、disableScroll)、project.config.json 项目配置。适用于创建新 Skyline 项目、迁移 WebView 项目、配置混合渲染。触发关键词:app.json、页面配置、renderer、rendererOptions、skyline配置、navigationStyle、disableScroll、componentFramework、glass-easel、project.config.json。
---
# Skyline JSON 配置规范
## 适用场景
- 创建新的 Skyline 小程序项目
- 从 WebView 迁移到 Skyline 渲染引擎
- 配置混合渲染(部分页面 Skyline、部分 WebView)
- 配置 rendererOptions 优化样式兼容性
- 排查 Skyline 配置相关的编译错误
## 核心概念
### 三级配置层次
| 层级 | 文件 | 作用 | 关键配置 |
|------|------|------|----------|
| 全局 | `app.json` | 全局启用 Skyline | renderer, componentFramework, rendererOptions |
| 页面 | `页面.json` | 页面级配置/覆盖 | navigationStyle, disableScroll, renderer |
| 工具 | `project.config.json` | 开发者工具调试 | setting.skylineRenderEnable |
### 最小必需配置
```json
// app.json
{
"renderer": "skyline",
"componentFramework": "glass-easel",
"lazyCodeLoading": "requiredComponents"
}
```
```json
// 每个页面的 .json
{
"navigationStyle": "custom"
}
```
## 文档索引
根据需求快速定位(路径相对于 `references/`):
| 我想要... | 查阅文档 |
|-----------|----------|
| 了解 app.json 中所有 Skyline 相关配置 | `app-config.md` |
| 了解页面级配置和混合渲染 | `page-config.md` |
| 配置开发者工具 | `project-config.md` |
| 查看完整配置模板 | `patterns.md` |
## 强制规则
### MUST(必须遵守)
1. **app.json 必须包含三项必需配置**:
```json
// ❌ 错误:缺少 componentFramework 和 lazyCodeLoading
{
"pages": ["pages/index/index"],
"renderer": "skyline"
}
// ✅ 正确:三项缺一不可
{
"renderer": "skyline",
"componentFramework": "glass-easel",
"lazyCodeLoading": "requiredComponents"
}
```
2. **每个页面的 json 必须配置 `"navigationStyle": "custom"`**:
```json
// ❌ 错误:缺少 navigationStyle,编译报错
// getAppConfig error: the "navigationStyle" configuration
// for the page should be set to "custom"
{
"usingComponents": {}
}
// ✅ 正确
{
"navigationStyle": "custom"
}
```
Skyline 不支持原生导航栏,必须使用自定义导航栏。
3. **使用 scroll-view 替代页面级滚动时配置 `"disableScroll": true`**:
```json
// ❌ 错误:未禁用页面滚动,可能与 scroll-view 冲突
{
"navigationStyle": "custom"
}
// ✅ 正确:禁用页面滚动,使用 scroll-view 管理滚动
{
"navigationStyle": "custom",
"disableScroll": true
}
```
4. **rendererOptions 应配置 defaultDisplayBlock 和 defaultContentBox 以对齐 WebView 行为**:
```json
// ❌ 错误:未配置 rendererOptions,Skyline 默认 display:flex + border-box
{
"renderer": "skyline"
}
// ✅ 正确:对齐 WebView 的 block + content-box 默认行为
{
"renderer": "skyline",
"rendererOptions": {
"skyline": {
"defaultDisplayBlock": true,
"defaultContentBox": true
}
}
}
```
### NEVER(禁止行为)
1. **NEVER** 遗漏任何页面的 `navigationStyle: "custom"` 配置——即使页面不需要导航栏,Skyline 下也必须声明
2. **NEVER** 在 Skyline 页面中依赖页面级全局滚动——Skyline 不支持页面级滚动,必须使用 `scroll-view` 组件
## Quick Reference
### 必需配置速查
| 配置项 | 位置 | 值 | 级别 |
|--------|------|-----|------|
| `renderer` | app.json | `"skyline"` | 必需 |
| `componentFramework` | app.json | `"glass-easel"` | 必需 |
| `lazyCodeLoading` | app.json | `"requiredComponents"` | 必需 |
| `navigationStyle` | 页面 json | `"custom"` | 必需 |
| `disableScroll` | 页面 json | `true` | 推荐 |
### rendererOptions 配置速查
| 配置项 | 类型 | 默认值 | 推荐值 | 说明 |
|--------|------|--------|--------|------|
| `defaultDisplayBlock` | boolean | false | true | 默认 display:block(对齐 WebView) |
| `defaultContentBox` | boolean | false | true | 默认 box-sizing:content-box(对齐 WebView) |
| `tagNameStyleIsolation` | string | "isolated" | "legacy" | 标签选择器全局匹配(对齐 WebView) |
| `enableScrollViewAutoSize` | boolean | false | true | scroll-view 自动撑开高度 |
| `disableABTest` | boolean | false | true | 关闭 Skyline AB 实验,确保稳定性 |
### 场景决策表
| 场景 | 推荐配置 |
|------|----------|
| 新建 Skyline 项目 | 三项必需 + rendererOptions 全部推荐值 |
| WebView 迁移 | 三项必需 + rendererOptions 兼容配置 + disableABTest |
| 混合渲染 | app.json 不设 renderer,页面级单独设 `"renderer": "skyline"` |
| 仅部分页面用 Skyline | 页面 json 中设 `"renderer": "skyline"` 覆盖全局 |
## 相关技能
| 场景 | 推荐技能 | 说明 |
|------|----------|------|
| WXSS 样式兼容 | `skyline-wxss` | rendererOptions 影响的默认值详解(display/flex-direction/align-items/box-sizing) |
| glass-easel 框架 | `skyline-glass-easel` | componentFramework 详细迁移指南 |
| Skyline 概览与迁移 | `skyline-overview` | 渲染引擎概览、迁移步骤 |
| 组件使用 | `skyline-components` | scroll-view 等组件配置 |
| 路由配置 | `skyline-route` | 自定义路由与页面转场 |
## References 目录结构
```
references/
├── app-config.md
├── page-config.md
├── patterns.md
└── project-config.md
```
Creator's repository · wechat-miniprogram/skyline-skills