tailwindcss-plugins by josiahsiegel/claude-plugin-marketplace
npx skills add https://github.com/josiahsiegel/claude-plugin-marketplace --skill tailwindcss-plugins为不受您控制的内容(Markdown、CMS 内容)提供美观的排版默认样式。
npm install -D @tailwindcss/typography
@import "tailwindcss";
@plugin "@tailwindcss/typography";
<article class="prose">
<h1>文章标题</h1>
<p>此内容将获得美观的默认样式...</p>
</article>
| 类名 | 描述 |
|---|---|
prose-sm | 较小文本(基准 14px) |
prose | 默认(基准 16px) |
prose-lg |
广告位招租
在这里展示您的产品或服务
触达数万 AI 开发者,精准高效
| 较大文本(基准 18px) |
prose-xl | 特大(基准 20px) |
prose-2xl | 巨大(基准 24px) |
<article class="prose md:prose-lg lg:prose-xl">
<!-- 响应式尺寸调整 -->
</article>
<article class="prose prose-slate">灰色主题</article>
<article class="prose prose-zinc">锌色主题</article>
<article class="prose prose-neutral">中性主题</article>
<article class="prose prose-stone">石色主题</article>
<article class="prose dark:prose-invert">
<!-- 自动为深色模式反转颜色 -->
</article>
覆盖特定元素:
<article class="
prose
prose-headings:text-blue-600
prose-a:text-blue-500
prose-a:no-underline
prose-code:text-pink-500
prose-img:rounded-lg
prose-strong:text-gray-900
prose-blockquote:border-blue-500
">
内容
</article>
<!-- 移除最大宽度限制 -->
<article class="prose max-w-none">
全宽内容
</article>
<article class="prose">
<h1>带样式的标题</h1>
<p>带样式的段落</p>
<div class="not-prose">
<!-- 此 div 及其子元素将排除排版样式 -->
<CustomComponent />
</div>
<p>恢复排版样式</p>
</article>
@plugin "@tailwindcss/typography" {
className: wysiwyg;
}
<article class="wysiwyg">内容</article>
将表单元素重置为一致且易于样式化的基准。
npm install -D @tailwindcss/forms
@import "tailwindcss";
@plugin "@tailwindcss/forms";
该插件将样式应用于:
input[type='text']input[type='email']input[type='password']input[type='number']input[type='url']input[type='date']input[type='datetime-local']input[type='month']input[type='week']input[type='time']input[type='search']input[type='tel']input[type='checkbox']input[type='radio']selectselect[multiple]textarea<!-- 文本输入框 -->
<input type="email" class="rounded-lg border-gray-300 focus:border-blue-500 focus:ring-blue-500">
<!-- 选择框 -->
<select class="rounded-lg border-gray-300">
<option>选项 1</option>
<option>选项 2</option>
</select>
<!-- 复选框 -->
<input type="checkbox" class="rounded text-blue-500 focus:ring-blue-500">
<!-- 单选按钮 -->
<input type="radio" class="text-blue-500 focus:ring-blue-500">
<!-- 文本域 -->
<textarea class="rounded-lg border-gray-300" rows="4"></textarea>
用于选择性样式化(不应用全局重置):
@plugin "@tailwindcss/forms" {
strategy: class;
}
<!-- 显式选择加入表单样式 -->
<input type="text" class="form-input rounded-lg">
<select class="form-select rounded-lg">
<textarea class="form-textarea rounded-lg">
<input type="checkbox" class="form-checkbox rounded">
<input type="radio" class="form-radio">
| 类名 | 元素 |
|---|---|
form-input | 文本输入框 |
form-textarea | 文本域 |
form-select | 选择框 |
form-multiselect | 多选选择框 |
form-checkbox | 复选框 |
form-radio | 单选按钮 |
<!-- 彩色复选框 -->
<input type="checkbox" class="rounded text-pink-500">
<!-- 强调色(原生) -->
<input type="checkbox" class="accent-purple-600">
<!-- 自定义尺寸 -->
<input type="checkbox" class="h-6 w-6 rounded text-blue-500">
根据元素容器的尺寸而非视口来设置样式。
npm install -D @tailwindcss/container-queries
@import "tailwindcss";
@plugin "@tailwindcss/container-queries";
<!-- 定义一个容器 -->
<div class="@container">
<!-- 使用容器查询断点 -->
<div class="flex flex-col @md:flex-row @lg:gap-8">
<div class="@sm:text-lg @md:text-xl">
响应容器,而非视口
</div>
</div>
</div>
| 前缀 | 宽度 |
|---|---|
@xs | 320px |
@sm | 384px |
@md | 448px |
@lg | 512px |
@xl | 576px |
@2xl | 672px |
@3xl | 768px |
@4xl | 896px |
@5xl | 1024px |
@6xl | 1152px |
@7xl | 1280px |
<!-- 为容器命名 -->
<div class="@container/sidebar">
<!-- 通过名称引用 -->
<div class="@md/sidebar:flex">
仅当侧边栏容器为 md 时 flex
</div>
</div>
<div class="@container/main">
<div class="@lg/main:grid-cols-3">
当主容器为 lg 时网格
</div>
</div>
<div class="@container">
<div class="@[400px]:flex @[600px]:grid">
任意断点值
</div>
</div>
对于简单的工具类,使用 @utility 指令而非 JavaScript 插件:
/* 在您的 CSS 文件中 */
@utility content-auto {
content-visibility: auto;
}
@utility text-balance {
text-wrap: balance;
}
@utility scrollbar-none {
scrollbar-width: none;
-ms-overflow-style: none;
}
@utility scrollbar-none::-webkit-scrollbar {
display: none;
}
对于需要 JavaScript 的复杂插件:
// plugins/my-plugin.js
import plugin from 'tailwindcss/plugin'
export default plugin(function({ addUtilities, addComponents, matchUtilities, theme }) {
// 添加静态工具类
addUtilities({
'.content-auto': {
'content-visibility': 'auto',
},
'.text-balance': {
'text-wrap': 'balance',
},
})
// 添加组件
addComponents({
'.btn': {
padding: theme('spacing.2') + ' ' + theme('spacing.4'),
borderRadius: theme('borderRadius.lg'),
fontWeight: theme('fontWeight.medium'),
},
'.btn-primary': {
backgroundColor: theme('colors.blue.500'),
color: theme('colors.white'),
'&:hover': {
backgroundColor: theme('colors.blue.600'),
},
},
})
// 添加动态工具类
matchUtilities(
{
'text-shadow': (value) => ({
textShadow: value,
}),
},
{ values: theme('textShadow') }
)
})
在 CSS 中加载:
@import "tailwindcss";
@plugin "./plugins/my-plugin.js";
// plugins/gradients.js
import plugin from 'tailwindcss/plugin'
export default plugin(
function({ matchUtilities, theme }) {
matchUtilities(
{
'text-gradient': (value) => ({
backgroundImage: value,
backgroundClip: 'text',
color: 'transparent',
}),
},
{ values: theme('textGradient') }
)
},
{
theme: {
textGradient: {
primary: 'linear-gradient(to right, #667eea, #764ba2)',
secondary: 'linear-gradient(to right, #f093fb, #f5576c)',
sunset: 'linear-gradient(to right, #fa709a, #fee140)',
},
},
}
)
// plugins/variants.js
import plugin from 'tailwindcss/plugin'
export default plugin(function({ addVariant }) {
// 同级状态
addVariant('peer-checked', ':merge(.peer):checked ~ &')
// 组状态
addVariant('group-focus-visible', ':merge(.group):focus-visible &')
// 数据属性
addVariant('data-active', '&[data-active="true"]')
addVariant('data-loading', '&[data-loading]')
// 自定义选择器
addVariant('hocus', ['&:hover', '&:focus'])
addVariant('not-first', '&:not(:first-child)')
addVariant('not-last', '&:not(:last-child)')
})
| 插件 | 描述 |
|---|---|
tailwindcss-animate | 动画工具类 |
tailwindcss-motion | 高级运动/动画 |
@headlessui/tailwindcss | Headless UI 变体 |
tailwind-scrollbar | 滚动条样式 |
tailwindcss-3d | 3D 变换工具类 |
tailwindcss-fluid-type | 流体排版 |
npm install -D tailwindcss-animate
@plugin "tailwindcss-animate";
<div class="animate-in fade-in slide-in-from-bottom-4 duration-500">
动画内容
</div>
<div class="animate-out fade-out slide-out-to-top-4 duration-300">
退出内容
</div>
/* 仅加载您实际使用的插件 */
@plugin "@tailwindcss/typography";
/* @plugin "@tailwindcss/forms"; -- 如果不使用则注释掉 */
在创建 JavaScript 插件之前,尝试使用 @utility 指令:
/* 简单的自定义工具类 - 无需 JS */
@utility glass {
backdrop-filter: blur(10px);
background: rgba(255, 255, 255, 0.1);
}
/**
* @name 文本渐变插件
* @description 添加文本渐变工具类
* @usage class="text-gradient-primary"
*/
export default plugin(...)
升级 Tailwind 时,验证所有插件是否适用于新版本:
npm outdated | grep tailwind
npm update @tailwindcss/typography @tailwindcss/forms
每周安装量
81
仓库
GitHub 星标
21
首次出现
Jan 24, 2026
安全审计
安装于
opencode62
gemini-cli61
codex58
claude-code57
github-copilot54
cursor54
Beautiful typographic defaults for content you don't control (Markdown, CMS content).
npm install -D @tailwindcss/typography
@import "tailwindcss";
@plugin "@tailwindcss/typography";
<article class="prose">
<h1>Article Title</h1>
<p>This content gets beautiful default styles...</p>
</article>
| Class | Description |
|---|---|
prose-sm | Smaller text (14px base) |
prose | Default (16px base) |
prose-lg | Larger text (18px base) |
prose-xl | Extra large (20px base) |
prose-2xl | Huge (24px base) |
<article class="prose md:prose-lg lg:prose-xl">
<!-- Responsive sizing -->
</article>
<article class="prose prose-slate">Gray theme</article>
<article class="prose prose-zinc">Zinc theme</article>
<article class="prose prose-neutral">Neutral theme</article>
<article class="prose prose-stone">Stone theme</article>
<article class="prose dark:prose-invert">
<!-- Automatically inverts for dark mode -->
</article>
Override specific elements:
<article class="
prose
prose-headings:text-blue-600
prose-a:text-blue-500
prose-a:no-underline
prose-code:text-pink-500
prose-img:rounded-lg
prose-strong:text-gray-900
prose-blockquote:border-blue-500
">
Content
</article>
<!-- Remove max-width constraint -->
<article class="prose max-w-none">
Full width content
</article>
<article class="prose">
<h1>Styled heading</h1>
<p>Styled paragraph</p>
<div class="not-prose">
<!-- This div and its children escape prose styles -->
<CustomComponent />
</div>
<p>Back to prose styles</p>
</article>
@plugin "@tailwindcss/typography" {
className: wysiwyg;
}
<article class="wysiwyg">Content</article>
Resets form elements to a consistent, easily-styleable baseline.
npm install -D @tailwindcss/forms
@import "tailwindcss";
@plugin "@tailwindcss/forms";
The plugin applies styles to:
input[type='text']input[type='email']input[type='password']input[type='number']input[type='url']input[type='date']input[type='datetime-local']input[type='month']input[type='week']input[type='time']<!-- Text input -->
<input type="email" class="rounded-lg border-gray-300 focus:border-blue-500 focus:ring-blue-500">
<!-- Select -->
<select class="rounded-lg border-gray-300">
<option>Option 1</option>
<option>Option 2</option>
</select>
<!-- Checkbox -->
<input type="checkbox" class="rounded text-blue-500 focus:ring-blue-500">
<!-- Radio -->
<input type="radio" class="text-blue-500 focus:ring-blue-500">
<!-- Textarea -->
<textarea class="rounded-lg border-gray-300" rows="4"></textarea>
For opt-in styling (doesn't apply global resets):
@plugin "@tailwindcss/forms" {
strategy: class;
}
<!-- Explicitly opt-in to form styles -->
<input type="text" class="form-input rounded-lg">
<select class="form-select rounded-lg">
<textarea class="form-textarea rounded-lg">
<input type="checkbox" class="form-checkbox rounded">
<input type="radio" class="form-radio">
| Class | Element |
|---|---|
form-input | Text inputs |
form-textarea | Textareas |
form-select | Selects |
form-multiselect | Multiple selects |
form-checkbox | Checkboxes |
form-radio | Radio buttons |
<!-- Colored checkbox -->
<input type="checkbox" class="rounded text-pink-500">
<!-- Accent color (native) -->
<input type="checkbox" class="accent-purple-600">
<!-- Custom size -->
<input type="checkbox" class="h-6 w-6 rounded text-blue-500">
Style elements based on their container's size instead of the viewport.
npm install -D @tailwindcss/container-queries
@import "tailwindcss";
@plugin "@tailwindcss/container-queries";
<!-- Define a container -->
<div class="@container">
<!-- Use container query breakpoints -->
<div class="flex flex-col @md:flex-row @lg:gap-8">
<div class="@sm:text-lg @md:text-xl">
Responsive to container, not viewport
</div>
</div>
</div>
| Prefix | Width |
|---|---|
@xs | 320px |
@sm | 384px |
@md | 448px |
@lg | 512px |
@xl | 576px |
@2xl | 672px |
@3xl |
<!-- Name the container -->
<div class="@container/sidebar">
<!-- Reference by name -->
<div class="@md/sidebar:flex">
Only flex when sidebar container is md
</div>
</div>
<div class="@container/main">
<div class="@lg/main:grid-cols-3">
Grid when main container is lg
</div>
</div>
<div class="@container">
<div class="@[400px]:flex @[600px]:grid">
Arbitrary breakpoint values
</div>
</div>
For simple utilities, use the @utility directive instead of a JavaScript plugin:
/* In your CSS file */
@utility content-auto {
content-visibility: auto;
}
@utility text-balance {
text-wrap: balance;
}
@utility scrollbar-none {
scrollbar-width: none;
-ms-overflow-style: none;
}
@utility scrollbar-none::-webkit-scrollbar {
display: none;
}
For complex plugins requiring JavaScript:
// plugins/my-plugin.js
import plugin from 'tailwindcss/plugin'
export default plugin(function({ addUtilities, addComponents, matchUtilities, theme }) {
// Add static utilities
addUtilities({
'.content-auto': {
'content-visibility': 'auto',
},
'.text-balance': {
'text-wrap': 'balance',
},
})
// Add components
addComponents({
'.btn': {
padding: theme('spacing.2') + ' ' + theme('spacing.4'),
borderRadius: theme('borderRadius.lg'),
fontWeight: theme('fontWeight.medium'),
},
'.btn-primary': {
backgroundColor: theme('colors.blue.500'),
color: theme('colors.white'),
'&:hover': {
backgroundColor: theme('colors.blue.600'),
},
},
})
// Add dynamic utilities
matchUtilities(
{
'text-shadow': (value) => ({
textShadow: value,
}),
},
{ values: theme('textShadow') }
)
})
Load in CSS:
@import "tailwindcss";
@plugin "./plugins/my-plugin.js";
// plugins/gradients.js
import plugin from 'tailwindcss/plugin'
export default plugin(
function({ matchUtilities, theme }) {
matchUtilities(
{
'text-gradient': (value) => ({
backgroundImage: value,
backgroundClip: 'text',
color: 'transparent',
}),
},
{ values: theme('textGradient') }
)
},
{
theme: {
textGradient: {
primary: 'linear-gradient(to right, #667eea, #764ba2)',
secondary: 'linear-gradient(to right, #f093fb, #f5576c)',
sunset: 'linear-gradient(to right, #fa709a, #fee140)',
},
},
}
)
// plugins/variants.js
import plugin from 'tailwindcss/plugin'
export default plugin(function({ addVariant }) {
// Peer states
addVariant('peer-checked', ':merge(.peer):checked ~ &')
// Group states
addVariant('group-focus-visible', ':merge(.group):focus-visible &')
// Data attributes
addVariant('data-active', '&[data-active="true"]')
addVariant('data-loading', '&[data-loading]')
// Custom selectors
addVariant('hocus', ['&:hover', '&:focus'])
addVariant('not-first', '&:not(:first-child)')
addVariant('not-last', '&:not(:last-child)')
})
| Plugin | Description |
|---|---|
tailwindcss-animate | Animation utilities |
tailwindcss-motion | Advanced motion/animation |
@headlessui/tailwindcss | Headless UI variants |
tailwind-scrollbar | Scrollbar styling |
tailwindcss-3d | 3D transform utilities |
tailwindcss-fluid-type |
npm install -D tailwindcss-animate
@plugin "tailwindcss-animate";
<div class="animate-in fade-in slide-in-from-bottom-4 duration-500">
Animated content
</div>
<div class="animate-out fade-out slide-out-to-top-4 duration-300">
Exiting content
</div>
/* Only load plugins you actually use */
@plugin "@tailwindcss/typography";
/* @plugin "@tailwindcss/forms"; -- commented out if not using */
Before creating a JavaScript plugin, try the @utility directive:
/* Simple custom utility - no JS needed */
@utility glass {
backdrop-filter: blur(10px);
background: rgba(255, 255, 255, 0.1);
}
/**
* @name Text Gradient Plugin
* @description Adds text gradient utilities
* @usage class="text-gradient-primary"
*/
export default plugin(...)
When upgrading Tailwind, verify all plugins work with the new version:
npm outdated | grep tailwind
npm update @tailwindcss/typography @tailwindcss/forms
Weekly Installs
81
Repository
GitHub Stars
21
First Seen
Jan 24, 2026
Security Audits
Gen Agent Trust HubPassSocketPassSnykPass
Installed on
opencode62
gemini-cli61
codex58
claude-code57
github-copilot54
cursor54
React 组合模式指南:Vercel 组件架构最佳实践,提升代码可维护性
120,000 周安装
input[type='search']input[type='tel']input[type='checkbox']input[type='radio']selectselect[multiple]textarea| 768px |
@4xl | 896px |
@5xl | 1024px |
@6xl | 1152px |
@7xl | 1280px |
| Fluid typography |