StyleKit
风格库模板社区生成器素材库GitHub
风格目录/圣杯布局

圣杯布局

Holy Grail Layout

D
51/100较差

经典的三栏式网页布局,由固定页头、三列中间区域(左侧导航、主内容、右侧边栏)和固定页脚组成,是Web设计的基础布局范式。

三栏圣杯经典页头页脚侧边栏导航
查看完整 Showcase →对比

配色方案

Primary

#1e293b

Secondary

#f1f5f9

Accent 1

#3b82f6

Accent 2

#10b981

Accent 3

#f59e0b

Accent 4

#ef4444

提示词

硬性 + 软性提示词

一键复制并生成 圣杯布局 风格界面。硬性提示词用于强约束一致性,软性提示词用于保留风格方向下的灵活实现。

硬性提示词

高一致性,严格执行风格规则

STYLEKIT_STYLE_REFERENCE
style_name: 圣杯布局
style_slug: holy-grail-layout
style_source: /styles/holy-grail-layout

# Hard Prompt

请严格遵守以下风格规则并保持一致性,禁止风格漂移。

## 执行要求
- 优先保证风格一致性,其次再做创意延展。
- 遇到冲突时以禁止项为最高优先级。
- 输出前自检:颜色、排版、间距、交互是否仍属于该风格。

## Style Rules
# Holy Grail Layout (圣杯布局) Design System

> 经典的三栏式网页布局,由固定页头、三列中间区域(左侧导航、主内容、右侧边栏)和固定页脚组成,是Web设计的基础布局范式。

## 核心理念

Holy Grail Layout 是Web设计中追求已久的经典布局方案,包含固定的页头页脚和三列中间内容区。这个名字来源于CSS布局早期实现这种布局的困难程度。

核心理念:
- 结构清晰:页头、三列内容、页脚五个区域各司其职
- 主内容优先:HTML 源码中主内容先于侧边栏,利于 SEO
- 等高列:三列无论内容多少都保持等高
- 灵活适配:侧边栏固定宽度,主内容区自适应

---

## Token 字典(精确 Class 映射)

### 边框
```
宽度: border
颜色: border-gray-200
圆角: rounded-xl
```

### 阴影
```
小:   shadow-sm
中:   shadow-sm
大:   shadow-md
悬停: hover:shadow-md
聚焦: focus:shadow-sm
```

### 交互效果
```
悬停位移: undefined
过渡动画: transition-colors duration-200
按下状态: active:scale-95
```

### 字体
```
标题: font-semibold tracking-tight
正文: font-sans
```

### 字号
```
Hero:  text-2xl md:text-3xl
H1:    text-xl md:text-2xl
H2:    text-lg md:text-xl
H3:    text-base md:text-lg
正文:  text-sm md:text-base
小字:  text-xs
```

### 间距
```
Section: py-4 md:py-6
容器:    px-4 md:px-6
卡片:    p-4 md:p-6
```

---

## [FORBIDDEN] 绝对禁止

以下 class 在本风格中**绝对禁止使用**,生成时必须检查并避免:

### 禁止的 Class
- `rounded-none`
- `shadow-2xl`
- `font-black`
- `font-extrabold`
- `text-5xl`
- `text-6xl`
- `text-7xl`
- `text-8xl`

### 禁止的模式
- 匹配 `^rounded-none$`
- 匹配 `^shadow-2xl`
- 匹配 `^text-[5-8]xl`

### 禁止原因
- `rounded-none`: Holy Grail Layout uses moderate rounding (rounded-xl) for a professional look
- `shadow-2xl`: Holy Grail Layout uses subtle shadows befitting a standard web layout
- `text-6xl`: Holy Grail Layout uses moderate type sizes for balanced three-column reading

> WARNING: 如果你的代码中包含以上任何 class,必须立即替换。

---

## [REQUIRED] 必须包含

### 按钮必须包含
```
rounded-lg
font-medium text-sm
transition-colors
```

### 卡片必须包含
```
bg-white
rounded-xl
shadow-sm
border border-gray-100
```

### 输入框必须包含
```
bg-gray-50
border border-gray-200
rounded-lg
text-sm
focus:outline-none
focus:ring-2 focus:ring-[#3b82f6]/20 focus:border-[#3b82f6]
transition-all
```

---

## [COMPARE] 错误 vs 正确对比

### 按钮

[WRONG] **错误示例**(使用了圆角和模糊阴影):
```html
<button class="rounded-lg shadow-lg bg-blue-500 text-white px-4 py-2 hover:bg-blue-600">
  点击我
</button>
```

[CORRECT] **正确示例**(使用硬边缘、无圆角、位移效果):
```html
<button class="rounded-lg font-medium text-sm transition-colors bg-[#ff006e] text-white px-4 py-2 md:px-6 md:py-3">
  点击我
</button>
```

### 卡片

[WRONG] **错误示例**(使用了渐变和圆角):
```html
<div class="rounded-xl shadow-2xl bg-gradient-to-r from-purple-500 to-pink-500 p-6">
  <h3 class="text-xl font-semibold">标题</h3>
</div>
```

[CORRECT] **正确示例**(纯色背景、硬边缘阴影):
```html
<div class="bg-white rounded-xl shadow-sm border border-gray-100 p-4 md:p-6">
  <h3 class="font-semibold tracking-tight text-base md:text-lg">标题</h3>
</div>
```

### 输入框

[WRONG] **错误示例**(灰色边框、圆角):
```html
<input class="rounded-md border border-gray-300 px-3 py-2 focus:ring-2 focus:ring-blue-500" />
```

[CORRECT] **正确示例**(黑色粗边框、聚焦阴影):
```html
<input class="bg-gray-50 border border-gray-200 rounded-lg text-sm focus:outline-none focus:ring-2 focus:ring-[#3b82f6]/20 focus:border-[#3b82f6] transition-all px-3 py-2 md:px-4 md:py-3" placeholder="请输入..." />
```

---

## [TEMPLATES] 页面骨架模板

使用以下模板生成页面,只需替换 `{PLACEHOLDER}` 部分:

### 导航栏骨架
```html
<nav class="bg-white border-b-2 md:border-b-4 border-black px-4 md:px-8 py-3 md:py-4">
  <div class="flex items-center justify-between max-w-6xl mx-auto">
    <a href="/" class="font-black text-xl md:text-2xl tracking-wider">
      {LOGO_TEXT}
    </a>
    <div class="flex gap-4 md:gap-8 font-mono text-sm md:text-base">
      {NAV_LINKS}
    </div>
  </div>
</nav>
```

### Hero 区块骨架
```html
<section class="min-h-[60vh] md:min-h-[80vh] flex items-center px-4 md:px-8 py-12 md:py-0 bg-{ACCENT_COLOR} border-b-2 md:border-b-4 border-black">
  <div class="max-w-4xl mx-auto">
    <h1 class="font-black text-4xl md:text-6xl lg:text-8xl leading-tight tracking-tight mb-4 md:mb-6">
      {HEADLINE}
    </h1>
    <p class="font-mono text-base md:text-xl max-w-xl mb-6 md:mb-8">
      {SUBHEADLINE}
    </p>
    <button class="bg-black text-white font-black px-6 py-3 md:px-8 md:py-4 border-2 md:border-4 border-black shadow-[4px_4px_0px_0px_rgba(255,0,110,1)] md:shadow-[8px_8px_0px_0px_rgba(255,0,110,1)] hover:shadow-none hover:translate-x-[2px] hover:translate-y-[2px] transition-all text-sm md:text-base">
      {CTA_TEXT}
    </button>
  </div>
</section>
```

### 卡片网格骨架
```html
<section class="py-12 md:py-24 px-4 md:px-8">
  <div class="max-w-6xl mx-auto">
    <h2 class="font-black text-2xl md:text-4xl mb-8 md:mb-12">{SECTION_TITLE}</h2>
    <div class="grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4 md:gap-6">
      <!-- Card template - repeat for each card -->
      <div class="bg-white border-2 md:border-4 border-black shadow-[4px_4px_0px_0px_rgba(0,0,0,1)] md:shadow-[8px_8px_0px_0px_rgba(0,0,0,1)] p-4 md:p-6 hover:shadow-[4px_4px_0px_0px_rgba(255,0,110,1)] md:hover:shadow-[8px_8px_0px_0px_rgba(255,0,110,1)] hover:-translate-y-1 transition-all">
        <h3 class="font-black text-lg md:text-xl mb-2">{CARD_TITLE}</h3>
        <p class="font-mono text-sm md:text-base text-gray-700">{CARD_DESCRIPTION}</p>
      </div>
    </div>
  </div>
</section>
```

### 页脚骨架
```html
<footer class="bg-black text-white py-12 md:py-16 px-4 md:px-8 border-t-2 md:border-t-4 border-black">
  <div class="max-w-6xl mx-auto">
    <div class="grid grid-cols-1 md:grid-cols-3 gap-8">
      <div>
        <span class="font-black text-xl md:text-2xl">{LOGO_TEXT}</span>
        <p class="font-mono text-sm mt-4 text-gray-400">{TAGLINE}</p>
      </div>
      <div>
        <h4 class="font-black text-lg mb-4">{COLUMN_TITLE}</h4>
        <ul class="space-y-2 font-mono text-sm text-gray-400">
          {FOOTER_LINKS}
        </ul>
      </div>
    </div>
  </div>
</footer>
```

---

## [CHECKLIST] 生成后自检清单

**在输出代码前,必须逐项验证以下每一条。如有违反,立即修正后再输出:**

### 1. 圆角检查
- [ ] 搜索代码中的 `rounded-`
- [ ] 确认只有 `rounded-none` 或无圆角
- [ ] 如果发现 `rounded-lg`、`rounded-md` 等,替换为 `rounded-none`

### 2. 阴影检查
- [ ] 搜索代码中的 `shadow-`
- [ ] 确认只使用 `shadow-[Xpx_Xpx_0px_0px_rgba(...)]` 格式
- [ ] 如果发现 `shadow-lg`、`shadow-xl` 等,替换为正确格式

### 3. 边框检查
- [ ] 搜索代码中的 `border-`
- [ ] 确认边框颜色是 `border-black`
- [ ] 如果发现 `border-gray-*`、`border-slate-*`,替换为 `border-black`

### 4. 交互检查
- [ ] 所有按钮都有 `hover:shadow-none hover:translate-x-[2px] hover:translate-y-[2px]`
- [ ] 所有卡片都有 hover 效果(阴影变色或位移)
- [ ] 都包含 `transition-all`

### 5. 响应式检查
- [ ] 边框有 `border-2 md:border-4`
- [ ] 阴影有 `shadow-[4px...] md:shadow-[8px...]`
- [ ] 间距有 `p-4 md:p-6` 或类似的响应式值
- [ ] 字号有 `text-sm md:text-base` 或类似的响应式值

### 6. 字体检查
- [ ] 标题使用 `font-black`
- [ ] 正文使用 `font-mono`

> CRITICAL: **如果任何一项检查不通过,必须修正后重新生成代码。**

---

## [EXAMPLES] 示例 Prompt

### 1. 管理后台

圣杯布局的管理后台

```
用 Holy Grail Layout 设计一个管理后台,要求:
1. 页头:logo + 搜索框 + 用户头像
2. 左侧导航:图标 + 文字菜单项
3. 主内容:数据卡片 + 表格
4. 右侧边栏:通知列表 + 快捷操作
5. 页脚:版权信息
6. 页头 sticky 固定,三列等高
7. 响应式折叠侧边栏
```

软性提示词

保留风格方向,允许实现灵活

STYLEKIT_STYLE_REFERENCE
style_name: 圣杯布局
style_slug: holy-grail-layout
style_source: /styles/holy-grail-layout

# Soft Prompt

保持整体风格气质即可,允许实现细节灵活调整,但不要偏离核心视觉语言。

## Style Signals
- 三栏
- 圣杯
- 经典
- 页头
- 页脚
- 侧边栏

## Prefer
- 使用 CSS Grid 或 Flexbox 实现等高三列
- 固定页头和页脚 sticky top-0 / sticky bottom-0
- 主内容区 flex-1 自适应宽度
- 左侧导航栏固定宽度 w-60 或 w-64

## Avoid
- 禁止三列高度不一致
- 禁止主内容区域过窄
- 禁止忽略响应式折叠

## Output Guidance
- 先保证整体风格识别度,再优化细节。
- 避免过度炫技,保持可读性与可维护性。

设计哲学

Holy Grail Layout 是Web设计中追求已久的经典布局方案,包含固定的页头页脚和三列中间内容区。这个名字来源于CSS布局早期实现这种布局的困难程度。

核心理念: - 结构清晰:页头、三列内容、页脚五个区域各司其职 - 主内容优先:HTML 源码中主内容先于侧边栏,利于 SEO - 等高列:三列无论内容多少都保持等高 - 灵活适配:侧边栏固定宽度,主内容区自适应

必须做 / Do's

  • +使用 CSS Grid 或 Flexbox 实现等高三列
  • +固定页头和页脚 sticky top-0 / sticky bottom-0
  • +主内容区 flex-1 自适应宽度
  • +左侧导航栏固定宽度 w-60 或 w-64
  • +右侧边栏固定宽度 w-64 或 w-72
  • +主内容在源码中先于侧边栏
  • +响应式折叠侧边栏
  • +所有按钮 active:scale-[0.98] active:translate-y-0 + focus:ring-2 focus:ring-[#3b82f6] focus:ring-offset-2
  • +内容卡片 hover:-translate-y-0.5 hover:shadow-md(轻量上浮,不干扰阅读)
  • +侧边导航 hover 时左边框高亮 hover:border-l-2 hover:border-[#3b82f6](无垂直位移,保持锚定感)
  • +所有动画 duration-150 ease-out(生产力工具要求响应利落)

禁止做 / Don'ts

  • -禁止三列高度不一致
  • -禁止主内容区域过窄
  • -禁止忽略响应式折叠
  • -禁止侧边栏宽度随内容变化
  • -禁止页头页脚不固定
  • -禁止卡片大幅位移动画(阅读场景下大幅运动破坏专注)
  • -禁止动画 duration 超过 200ms(生产力工具应当响应利落)
  • -禁止按钮缺少 active:scale-[0.98](无触觉确认)
  • -禁止侧边导航 hover 时有垂直位移(锚定感要求无移动)

组件模板

组件预览

按钮

圣杯布局三态按钮:hover:-translate-y-0.5 轻量浮起,active:scale-[0.98] 触觉按压,focus:ring-2 WCAG 焦点环,duration-150 crisp 响应

tsx
<button className="
  px-4 py-2
  bg-[#3b82f6] text-white
  rounded-lg
  font-medium text-sm
  hover:bg-[#2563eb] hover:-translate-y-0.5
  hover:shadow-[0_4px_10px_rgba(59,130,246,0.4)]
  focus:outline-none focus:ring-2 focus:ring-[#3b82f6] focus:ring-offset-2
  active:scale-[0.98] active:bg-[#1d4ed8] active:translate-y-0 active:shadow-none
  transition-all duration-150 ease-out
">
  Action
</button>

全局样式

全局 CSS

css
/* Holy Grail Layout 全局样式 */

/* 圣杯布局容器 */
.holy-grail {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* 页头 */
.holy-grail-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: white;
  border-bottom: 1px solid #e2e8f0;
}

/* 三列主体 */
.holy-grail-body {
  display: flex;
  flex: 1;
}

/* 左侧导航栏 */
.holy-grail-nav {
  width: 240px;
  flex-shrink: 0;
  background: white;
  border-right: 1px solid #e2e8f0;
  padding: 1rem;
}

/* 主内容区 */
.holy-grail-main {
  flex: 1;
  padding: 1.5rem;
  min-width: 0;
}

/* 右侧边栏 */
.holy-grail-aside {
  width: 256px;
  flex-shrink: 0;
  background: white;
  border-left: 1px solid #e2e8f0;
  padding: 1rem;
}

/* 页脚 */
.holy-grail-footer {
  background: white;
  border-top: 1px solid #e2e8f0;
  padding: 1rem 1.5rem;
  text-align: center;
}

/* 响应式 */
@media (max-width: 1024px) {
  .holy-grail-aside {
    display: none;
  }
}

@media (max-width: 768px) {
  .holy-grail-body {
    flex-direction: column;
  }
  .holy-grail-nav {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid #e2e8f0;
  }
}

兼容的视觉风格

试试搭配

圣杯布局 是一种布局模式,可以与以下视觉风格搭配使用。

企业简洁风

Corporate Clean

编辑杂志风

Editorial

Notion 风格

Notion Style

极简扁平风

Minimalist Flat

暗黑模式

Dark Mode

无障碍

无障碍评分

基于颜色对比度和排版可读性的 WCAG 2.1 合规分析。

51

综合评分

等级: D - 较差

对比度

分数: 43/100平均比率: 5.67:1
AA 未通过AAA 未通过
场景颜色比率AAAAA
Text on background
/#1e293b / #f1f5f9
13.35:1
Secondary text on background
/#4b5563 / #f1f5f9
6.9:1
Muted text on background
/#9ca3af / #f1f5f9
2.32:1
Text on secondary background
/#1e293b / #ffffff
14.63:1
Secondary text on secondary
/#4b5563 / #ffffff
7.56:1
Button primary
/#ffffff / #3b82f6
3.68:1
Text on accent 1
/#1e293b / #3b82f6
3.98:1
Alt text on accent 1
/#4b5563 / #3b82f6
2.05:1
Text on accent 2
/#1e293b / #10b981
5.77:1
Alt text on accent 2
/#4b5563 / #10b981
2.98:1
Text on accent 3
/#1e293b / #f59e0b
6.81:1
Alt text on accent 3
/#4b5563 / #f59e0b
3.52:1
Text on accent 4
/#1e293b / #ef4444
3.89:1
Alt text on accent 4
/#4b5563 / #ef4444
2.01:1

可读性

分数

68/100

字号

text-sm md:text-base

字重

font-semibold tracking-tight

行高

default

评分基于 WCAG 2.1 标准。AA 级要求普通文本对比度 4.5:1、大文本 3:1;AAA 级要求普通文本 7:1、大文本 4.5:1。

IDE 集成

IDE 配置导出

下载 AI 编码助手的配置文件,使其按照此风格生成代码。

风格包

导出风格包

获取完整的可机器读取风格资源,包括 Design Tokens、Tailwind 预设、CSS 变量和 shadcn/ui 主题。

Metadata

Style metadata including version information

Design Tokens

Figma / Style Dictionary / Tokens Studio 兼容

Tailwind Preset

Tailwind CSS 主题预设,可直接在配置中引用

Global CSS

包含 CSS 变量和基础样式

shadcn Theme

shadcn/ui 主题配置

CSS Variables

纯 CSS 变量,适用于任何项目

SKILL.md

可加载到 Cursor / Claude Code / VS Code 的技能包

社区

评分与反馈

登录后评分
0 条评论
登录后才能发表评论。 去登录

StyleKit

精选网页设计风格库,帮助 AI 生成更好看的网站。

导航

风格库模板对比

资源

GitHub 仓库

(c) 2026 StyleKit. 开源项目。

基于 Editorial 风格构建