Notion 风格
Notion Style
极简清爽的文档工具风格,强调内容可读性和功能性,使用微妙的边框、柔和的悬停效果和清晰的文字层级。
配色方案
Primary
#37352f
Secondary
#ffffff
Accent 1
#2eaadc
Accent 2
#eb5757
Accent 3
#0f7b6c
提示词
硬性 + 软性提示词
一键复制并生成 Notion 风格 风格界面。硬性提示词用于强约束一致性,软性提示词用于保留风格方向下的灵活实现。
硬性提示词
高一致性,严格执行风格规则
STYLEKIT_STYLE_REFERENCE
style_name: Notion 风格
style_slug: notion-style
style_source: /styles/notion-style
# Hard Prompt
请严格遵守以下风格规则并保持一致性,禁止风格漂移。
## 执行要求
- 优先保证风格一致性,其次再做创意延展。
- 遇到冲突时以禁止项为最高优先级。
- 输出前自检:颜色、排版、间距、交互是否仍属于该风格。
## Style Rules
# Notion Style (Notion 风格) Design System
> 极简清爽的文档工具风格,强调内容可读性和功能性,使用微妙的边框、柔和的悬停效果和清晰的文字层级。
## 核心理念
Notion Style 是一种源于 Notion 应用的极简设计风格,强调内容的可读性和功能的直观性。通过微妙的视觉元素和清晰的层级结构,让用户专注于内容本身。
核心理念:
- 内容优先:设计服务于内容,不喧宾夺主
- 功能清晰:每个元素都有明确的功能目的
- 微妙交互:悬停和点击反馈轻柔自然
- 层级分明:通过字体大小和颜色区分信息层级
---
## Token 字典(精确 Class 映射)
### 边框
```
宽度: border
颜色: border-gray-200
圆角: rounded-md
```
### 阴影
```
小: shadow-sm
中: shadow-md
大: shadow-lg
悬停: hover:shadow-md
聚焦: focus:shadow-sm
```
### 交互效果
```
悬停位移: undefined
过渡动画: transition-colors duration-150
按下状态: active:scale-95
```
### 字体
```
标题: font-semibold text-gray-900
正文: text-gray-700
```
### 字号
```
Hero: text-4xl md:text-5xl
H1: text-3xl md:text-4xl
H2: text-2xl md:text-3xl
H3: text-xl md:text-2xl
正文: text-base
小字: text-sm
```
### 间距
```
Section: py-12 md:py-16
容器: px-4 md:px-6
卡片: p-4 md:p-6
```
---
## [FORBIDDEN] 绝对禁止
以下 class 在本风格中**绝对禁止使用**,生成时必须检查并避免:
### 禁止的 Class
- `rounded-2xl`
- `rounded-3xl`
- `rounded-full`
- `shadow-2xl`
- `bg-gradient-to-r`
- `bg-gradient-to-br`
### 禁止的模式
- 匹配 `^rounded-(?:2xl|3xl|full)`
- 匹配 `^shadow-(?:2xl|inner)`
- 匹配 `^bg-gradient`
### 禁止原因
- `rounded-2xl`: Notion style uses subtle rounded corners (rounded-md or rounded-lg)
- `rounded-full`: Notion style avoids pill-shaped elements except for avatars
- `shadow-2xl`: Notion style uses minimal, subtle shadows
- `bg-gradient-to-r`: Notion style uses flat, solid colors without gradients
> WARNING: 如果你的代码中包含以上任何 class,必须立即替换。
---
## [REQUIRED] 必须包含
### 按钮必须包含
```
px-3 py-1.5
rounded-md
text-sm font-medium
hover:bg-gray-100
transition-colors duration-150
```
### 卡片必须包含
```
bg-white
border border-gray-200
rounded-lg
shadow-sm
```
### 输入框必须包含
```
bg-white
border border-gray-200
rounded-md
text-gray-900 placeholder-gray-400
focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent
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="px-3 py-1.5 rounded-md text-sm font-medium hover:bg-gray-100 transition-colors duration-150 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 border border-gray-200 rounded-lg shadow-sm p-4 md:p-6">
<h3 class="font-semibold text-gray-900 text-xl md:text-2xl">标题</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-white border border-gray-200 rounded-md text-gray-900 placeholder-gray-400 focus:outline-none focus:ring-2 focus:ring-blue-500 focus:border-transparent 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. 文档页面
Notion 风格文档布局
```
用 Notion Style 创建一个文档页面,要求:
1. 左侧:固定侧边栏,米色背景,页面列表
2. 右侧:主内容区,白色背景
3. 标题:大号字体,可编辑感
4. 内容块:段落、列表、代码块
5. 悬停效果:微妙的背景色变化
```
### 2. 任务看板
Notion 风格看板视图
```
用 Notion Style 设计一个任务看板,要求:
1. 多列布局:To Do, In Progress, Done
2. 任务卡片:白色背景,微妙边框,小圆角
3. 拖拽指示:悬停时显示抓取光标
4. 添加按钮:简洁的 + 图标
5. 标签:彩色小标签(蓝、红、绿、黄)
```软性提示词
保留风格方向,允许实现灵活
STYLEKIT_STYLE_REFERENCE
style_name: Notion 风格
style_slug: notion-style
style_source: /styles/notion-style
# Soft Prompt
保持整体风格气质即可,允许实现细节灵活调整,但不要偏离核心视觉语言。
## Style Signals
- Notion
- 文档
- 极简
- 清爽
- 工具
- 协作
## Prefer
- 使用 Notion 标志性的米色背景 #f7f6f3
- 使用微妙的边框 border-gray-200
- 悬停效果使用浅灰背景 hover:bg-gray-100
- 保持清晰的文字层级
## Avoid
- 禁止使用大圆角 rounded-2xl 或更大
- 禁止使用渐变背景
- 禁止使用重阴影
## Output Guidance
- 先保证整体风格识别度,再优化细节。
- 避免过度炫技,保持可读性与可维护性。设计哲学
Notion Style 是一种源于 Notion 应用的极简设计风格,强调内容的可读性和功能的直观性。通过微妙的视觉元素和清晰的层级结构,让用户专注于内容本身。
核心理念: - 内容优先:设计服务于内容,不喧宾夺主 - 功能清晰:每个元素都有明确的功能目的 - 微妙交互:悬停和点击反馈轻柔自然 - 层级分明:通过字体大小和颜色区分信息层级
必须做 / Do's
- +使用 Notion 标志性的米色背景 #f7f6f3
- +使用微妙的边框 border-gray-200
- +悬停效果使用浅灰背景 hover:bg-gray-100
- +保持清晰的文字层级
- +使用系统字体栈确保可读性
- +图标使用简洁的线性风格
- +卡片使用 group 类,hover 时左侧拖拽手柄 ⋮⋮ 从 opacity-0 变为 opacity-100(Drag Handle Illusion,Notion 标志性 UX 模式)
- +悬停背景仅从 #f7f6f3 变为 #efedea(Block Highlighting,极低信噪比反馈)
- +active 状态仅加深背景色至 #e3e1db,禁止任何位移或缩放(Micro-click,文档工具的克制触感)
- +所有过渡 duration-150,保持效率工具的即时响应感
- +按钮使用透明底色 bg-transparent,hover:bg-[#efedea] active:bg-[#e3e1db](Ultimate Restraint,无浮起无缩放)
禁止做 / Don'ts
- -禁止使用大圆角 rounded-2xl 或更大
- -禁止使用渐变背景
- -禁止使用重阴影
- -禁止使用过于鲜艳的颜色
- -禁止过度装饰
- -禁止任何 translate 或 scale 动画(破坏文档工具的阅读稳定性)
- -禁止 hover 时出现边框变化或阴影跳变(信噪比过高,干扰用户专注内容)
- -禁止按钮使用 hover:-translate-y-* 上浮效果(Notion 是平铺文档,无漂浮感)
组件模板
组件预览
按钮
Notion 风格按钮,极度克制的 Block Highlighting + Micro-click 反馈
<button className="
px-3 py-1.5
bg-transparent
rounded
text-sm font-medium text-[#37352f]
hover:bg-[#efedea]
active:bg-[#e3e1db]
transition-colors duration-150
flex items-center gap-2
">
<svg className="w-4 h-4 text-gray-500" fill="none" stroke="currentColor" viewBox="0 0 24 24">
<path strokeLinecap="round" strokeLinejoin="round" strokeWidth={1.5} d="M12 4v16m8-8H4" />
</svg>
New page
</button>全局样式
全局 CSS
/* Notion Style 全局样式 */
:root {
--notion-text: #37352f;
--notion-text-gray: #9b9a97;
--notion-bg: #ffffff;
--notion-bg-gray: #f7f6f3;
--notion-blue: #2eaadc;
--notion-red: #eb5757;
--notion-green: #0f7b6c;
--notion-yellow: #dfab01;
--notion-border: rgba(55, 53, 47, 0.09);
}
/* 基础文字样式 */
body {
font-family: ui-sans-serif, -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, "Apple Color Emoji", Arial, sans-serif;
color: var(--notion-text);
line-height: 1.5;
}
/* Notion 风格链接 */
.notion-link {
color: var(--notion-text);
text-decoration: underline;
text-decoration-color: rgba(55, 53, 47, 0.4);
text-underline-offset: 2px;
}
.notion-link:hover {
text-decoration-color: var(--notion-text);
}
/* Notion 风格代码块 */
.notion-code {
font-family: SFMono-Regular, Menlo, Consolas, "PT Mono", "Liberation Mono", Courier, monospace;
font-size: 85%;
background: rgba(135, 131, 120, 0.15);
border-radius: 3px;
padding: 0.2em 0.4em;
}
/* Notion 风格分割线 */
.notion-divider {
border: none;
border-top: 1px solid var(--notion-border);
margin: 1rem 0;
}无障碍
无障碍评分
基于颜色对比度和排版可读性的 WCAG 2.1 合规分析。
综合评分
等级: C - 一般
对比度
| 场景 | 颜色 | 比率 | AA | AAA |
|---|---|---|---|---|
| Text on background | /#37352f / #ffffff | 12.26:1 | ||
| Secondary text on background | /#4b5563 / #ffffff | 7.56:1 | ||
| Muted text on background | /#9ca3af / #ffffff | 2.54:1 | ||
| Text on secondary background | /#37352f / #f7f6f3 | 11.35:1 | ||
| Secondary text on secondary | /#4b5563 / #f7f6f3 | 6.99:1 | ||
| Button primary | /#ffffff / #2eaadc | 2.66:1 |
可读性
分数
77/100
字号
text-base
字重
font-semibold text-gray-900
行高
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 的技能包