StyleKit
风格库模板社区生成器素材库GitHub
风格目录/瑞士海报风

瑞士海报风

Swiss Poster

B
82/100良好

大胆排版、网格对齐、原色色块和实验性布局。源于瑞士国际主义海报设计传统,以超大字体和强烈的视觉层次构建信息传达。与 swiss-style 的区别在于更注重海报级别的实验性大排版。

海报大字体网格实验排版国际主义12列网格色块
查看完整 Showcase →对比

配色方案

Primary

#000000

Secondary

#ffffff

Accent 1

#ff0000

Accent 2

#0057b8

Accent 3

#ffcc00

提示词

硬性 + 软性提示词

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

硬性提示词

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

STYLEKIT_STYLE_REFERENCE
style_name: 瑞士海报风
style_slug: swiss-poster
style_source: /styles/swiss-poster

# Hard Prompt

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

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

## Style Rules
# Swiss Poster (瑞士海报风) Design System

> 大胆排版、网格对齐、原色色块和实验性布局。源于瑞士国际主义海报设计传统,以超大字体和强烈的视觉层次构建信息传达。与 swiss-style 的区别在于更注重海报级别的实验性大排版。

## 核心理念

Swiss Poster 风格源于瑞士国际主义设计运动的海报传统,追求极致的排版表现力。

核心理念:
- 超大排版:使用极端大小的字体创造视觉冲击(160px 标题 vs 10px 标签)
- 12列网格系统:所有内容严格对齐到 grid-cols-12,使用非对称分栏
- 原色色块:黑白为主,红蓝黄作为大面积色块强调
- 边框分隔:使用 border-2 border-[#000000] 分隔区域,不使用阴影或间距
- 零间距:gap-0 让元素边缘紧贴,以边框线作为视觉分隔
- 无装饰:没有圆角、阴影、渐变、模糊,只有纯色和线条

---

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

### 边框
```
宽度: border-2
颜色: border-[#000000]
圆角: rounded-none
```

### 阴影
```
小:   shadow-none
中:   shadow-none
大:   shadow-none
悬停: shadow-none
聚焦: shadow-none
```

### 交互效果
```
悬停位移: hover:-translate-y-0.5
过渡动画: transition-all duration-100 ease-out
按下状态: active:scale-[0.98]
```

### 字体
```
标题: font-sans font-black uppercase tracking-tighter
正文: font-sans
```

### 字号
```
Hero:  text-6xl md:text-[10rem] lg:text-[12rem]
H1:    text-5xl md:text-7xl lg:text-8xl
H2:    text-3xl md:text-5xl lg:text-6xl
H3:    text-xl md:text-2xl lg:text-3xl
正文:  text-sm md:text-base
小字:  text-xs md:text-sm
```

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

---

## [FORBIDDEN] 绝对禁止

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

### 禁止的 Class
- `rounded-md`
- `rounded-lg`
- `rounded-xl`
- `rounded-2xl`
- `rounded-full`
- `bg-gradient-to-r`
- `bg-gradient-to-b`
- `bg-gradient-to-br`
- `shadow-sm`
- `shadow-md`
- `shadow-lg`
- `shadow-xl`
- `backdrop-blur`
- `backdrop-blur-sm`
- `font-serif`
- `font-mono`
- `border-dashed`
- `gap-4`
- `gap-6`
- `gap-8`

### 禁止的模式
- 匹配 `^rounded-(?:md|lg|xl|2xl|full)$`
- 匹配 `^bg-gradient-`
- 匹配 `^shadow-(?:sm|md|lg|xl|2xl)$`
- 匹配 `^backdrop-blur`
- 匹配 `^font-serif$`
- 匹配 `^font-mono$`

### 禁止原因
- `rounded-lg`: Swiss Poster uses sharp edges only (rounded-none) - geometric precision
- `bg-gradient-to-r`: Swiss Poster uses flat solid color blocks only, no gradients
- `shadow-md`: Swiss Poster does not use shadows at all - relies on borders and color blocks for hierarchy
- `backdrop-blur`: Swiss Poster is clean and opaque, no blur or glass effects
- `font-serif`: Swiss Poster uses sans-serif only (Helvetica/Akzidenz-Grotesk tradition)
- `font-mono`: Swiss Poster uses sans-serif only - monospace breaks the typographic tradition
- `border-dashed`: Swiss Poster uses solid borders only - dashed lines break the clean grid aesthetic
- `gap-4`: Swiss Poster uses gap-0 - elements butt against each other with borders as separators

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

---

## [REQUIRED] 必须包含

### 按钮必须包含
```
rounded-none
font-sans font-black uppercase tracking-widest
border-2 border-[#000000]
transition-all duration-100 ease-out
```

### 卡片必须包含
```
rounded-none
bg-[#ffffff]
border-2 border-[#000000]
```

### 输入框必须包含
```
rounded-none
border-0 border-b-2 border-[#000000]
bg-transparent
font-sans font-bold
focus:outline-none
```

---

## [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-none font-sans font-black uppercase tracking-widest border-2 border-[#000000] transition-all duration-100 ease-out 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="rounded-none bg-[#ffffff] border-2 border-[#000000] p-6 md:p-8">
  <h3 class="font-sans font-black uppercase tracking-tighter text-xl md:text-2xl lg:text-3xl">标题</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="rounded-none border-0 border-b-2 border-[#000000] bg-transparent font-sans font-bold focus:outline-none 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. 瑞士海报着陆页

12列网格非对称布局的海报风格着陆页

```
Use Swiss Poster style to create a landing page:
1. Background: white with visible 12-column structural grid
2. Title: extremely large (160px) black sans-serif, uppercase, tight tracking
3. Layout: asymmetric grid-cols-12 splits (8/4, 3/9), never symmetric
4. Cards: border-only, no shadows, color block hover states
5. Buttons: edge-to-edge gap-0, joined with border-l-0
6. Color blocks: large red/blue/yellow sections as accents
7. Section dividers: border-2 border-[#000000], no spacing
8. Overall bold, grid-based, mathematical typographic poster aesthetic
```

软性提示词

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

STYLEKIT_STYLE_REFERENCE
style_name: 瑞士海报风
style_slug: swiss-poster
style_source: /styles/swiss-poster

# Soft Prompt

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

## Style Signals
- 海报
- 大字体
- 网格
- 实验排版
- 国际主义
- 12列网格

## Prefer
- 使用超大号无衬线粗体字(font-sans font-black)
- 严格遵循 12 列网格对齐(grid-cols-12)
- 使用黑白为主色调
- 使用原色(红 #ff0000、蓝 #0057b8、黄 #ffcc00)作为色块强调

## Avoid
- 禁止使用装饰性字体或等宽字体
- 禁止使用超过 rounded-sm 的圆角
- 禁止使用任何阴影(shadow-sm 及以上)

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

设计哲学

Swiss Poster 风格源于瑞士国际主义设计运动的海报传统,追求极致的排版表现力。

核心理念: - 超大排版:使用极端大小的字体创造视觉冲击(160px 标题 vs 10px 标签) - 12列网格系统:所有内容严格对齐到 grid-cols-12,使用非对称分栏 - 原色色块:黑白为主,红蓝黄作为大面积色块强调 - 边框分隔:使用 border-2 border-[#000000] 分隔区域,不使用阴影或间距 - 零间距:gap-0 让元素边缘紧贴,以边框线作为视觉分隔 - 无装饰:没有圆角、阴影、渐变、模糊,只有纯色和线条

必须做 / Do's

  • +使用超大号无衬线粗体字(font-sans font-black)
  • +严格遵循 12 列网格对齐(grid-cols-12)
  • +使用黑白为主色调
  • +使用原色(红 #ff0000、蓝 #0057b8、黄 #ffcc00)作为色块强调
  • +保持直角边缘(rounded-none)
  • +文字全部大写(uppercase tracking-widest)
  • +使用 border-2 border-[#000000] 分隔区域
  • +使用 gap-0 让元素紧贴
  • +使用非对称布局(如 3/9、8/4 分栏)
  • +Absolute Objectivity: zero translate, scale, or shadow on any element — Swiss Poster communicates through color and typography alone, motion is noise
  • +Snap Transitions: all interactions use `transition-none` — color changes are instantaneous hard cuts, like ink stamped onto paper
  • +Color Block Invasion: hover replaces background with solid black `hover:bg-[#000000]` and text inverts to white `hover:text-[#ffffff]` — the color block takes over the entire element
  • +Typographic Highlighting: year/label element switches to `group-hover:text-[#ff0000] transition-none` on hover — the red typographic accent activates like a stamp

禁止做 / Don'ts

  • -禁止使用装饰性字体或等宽字体
  • -禁止使用超过 rounded-sm 的圆角
  • -禁止使用任何阴影(shadow-sm 及以上)
  • -禁止使用渐变
  • -禁止使用虚线边框(border-dashed)
  • -禁止使用元素间距(gap-4 等),用 gap-0 + 边框
  • -禁止使用任何 `translate`、`scale` 或 `rotate` 动画(Absolute Objectivity — Swiss Poster 用色彩和排版传达,不用运动)
  • -禁止使用 `active:scale-[0.98]` 或任何 scale(海报不会因为被触碰而缩放)
  • -禁止使用 `transition-all duration-*` 中任何非零延迟(必须 `transition-none` — 印刷颜色切换是瞬时的)
  • -禁止 hover 只改变文字颜色而不改变背景(Color Block Invasion 要求整块颜色翻转,不只是文字变色)

组件模板

组件预览

按钮

Swiss Poster 风格按钮,Color Block Invasion 整块颜色翻转 + Snap Transitions `transition-none` + active 反转为白底黑字

tsx
<button className="
  px-8 py-3
  bg-[#000000] text-[#ffffff]
  font-sans font-black uppercase tracking-widest
  rounded-none
  border-2 border-[#000000]
  hover:bg-[#ff0000] hover:border-[#ff0000]
  active:bg-[#ffffff] active:text-[#000000] active:border-[#000000]
  transition-none
">
  ENTER
</button>

全局样式

全局 CSS

css
/* Swiss Poster Global Styles */

:root {
  --sp-black: #000000;
  --sp-white: #ffffff;
  --sp-red: #ff0000;
  --sp-blue: #0057b8;
  --sp-yellow: #ffcc00;
}

/* Structural grid overlay for development */
.sp-grid-overlay {
  background-image:
    linear-gradient(rgba(0, 0, 0, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0, 0, 0, 0.03) 1px, transparent 1px);
  background-size: calc(100% / 12) 100px;
}

/* Color block accents */
.sp-block-red { background-color: var(--sp-red); }
.sp-block-blue { background-color: var(--sp-blue); }
.sp-block-yellow { background-color: var(--sp-yellow); }

/* Tight tracking for poster headings */
.sp-tight { letter-spacing: -0.05em; }

/* Structural divider line */
.sp-divider {
  border-top: 2px solid var(--sp-black);
}

/* Vertical text for sidebar labels */
.sp-vertical-text {
  writing-mode: vertical-lr;
  transform: rotate(180deg);
  letter-spacing: 0.5em;
}

/* Asymmetric grid helper - 3/9 split */
.sp-grid-3-9 {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
}
.sp-grid-3-9 > :first-child { grid-column: span 3; }
.sp-grid-3-9 > :last-child { grid-column: span 9; }

/* Edge-to-edge buttons */
.sp-button-group {
  display: flex;
  gap: 0;
}
.sp-button-group > * + * {
  border-left: 0;
}

无障碍

无障碍评分

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

82

综合评分

等级: B - 良好

对比度

分数: 82/100平均比率: 13.91:1
AA 未通过AAA 未通过
场景颜色比率AAAAA
Text on background
/#000000 / #ffffff
21:1
Secondary text on background
/#000000 / #ffffff
21:1
Muted text on background
/#000000 / #ffffff
21:1
Text on secondary background
/#000000 / #f5f5f5
19.26:1
Secondary text on secondary
/#000000 / #f5f5f5
19.26:1
Button primary
/#ffffff / #000000
21:1
Text on accent 1
/#000000 / #ff0000
5.25:1
Alt text on accent 1
/#000000 / #ff0000
5.25:1
Text on accent 2
/#000000 / #0057b8
3.06:1
Alt text on accent 2
/#000000 / #0057b8
3.06:1
Text on accent 3
/#000000 / #ffcc00
13.89:1
Alt text on accent 3
/#000000 / #ffcc00
13.89:1

可读性

分数

83/100

字号

text-sm md:text-base

字重

font-sans font-black uppercase tracking-tighter

行高

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 风格构建