ToolDeck

فشرده‌ساز CSS

CSS را با حذف فضاهای خالی و کامنت‌ها فشرده کنید

یک مثال امتحان کنید

ورودی CSS

CSS فشرده‌شده

به‌صورت محلی اجرا می‌شود · جای‌گذاری اسرار امن است
CSS فشرده‌شده اینجا نمایش داده می‌شود…
همچنین امتحان کنید:فرمت‌کننده CSSمبدل واحدهای CSS

فشرده‌سازی CSS چیست؟

فشرده‌سازی CSS فرآیند حذف تمام کاراکترهای غیرضروری از یک استایل‌شیت بدون تغییر رفتار آن است. این یعنی حذف فضای خالی، شکست خط، کامنت‌ها و نحو اضافی مانند سمی‌کالن‌های انتهایی و کوتیشن‌های غیرضروری. مرورگر CSS فشرده‌شده را دقیقاً مانند نسخه اصلی تجزیه می‌کند. طبق مشخصات W3C، فضای خالی بین توکن‌های CSS اختیاری است مگر جایی که شناسه‌ها را از هم جدا کند. فشرده‌سازی از این ویژگی بهره می‌گیرد و همه چیز را به حداقل کاراکترهای لازم تقلیل می‌دهد.

یک فشرده‌ساز CSS آنلاین استایل‌شیت قالب‌بندی‌شده شما را می‌گیرد و نسخه‌ای فشرده و بهینه‌شده برای حجم انتقال تولید می‌کند. صرفه‌جویی معمول بین ۱۵ تا ۴۰ درصد است، بسته به میزان فضای خالی و تعداد کامنت‌های موجود در سورس. برای یک استایل‌شیت ۵۰ کیلوبایتی، این به معنای ۷ تا ۲۰ کیلوبایت کمتر در هر بارگذاری صفحه است. ترکیب این روش با فشرده‌سازی gzip یا Brotli در سرور، حجم نهایی انتقال را بیشتر کاهش می‌دهد زیرا خروجی فشرده‌شده CSS از پیش مینیفای‌شده کوچک‌تر از خروجی فشرده‌سازی نسخه قالب‌بندی‌شده اصلی است.

فشرده‌سازی یک مرحله استاندارد در پایپ‌لاین‌های build فرانت‌اند است. ابزارهایی مانند cssnano، clean-css و esbuild فشرده‌سازی را به‌عنوان بخشی از فرآیند build اجرا می‌کنند. اما در طول توسعه، گاهی لازم است یک قطعه کد را برای آزمایش فشرده کنید، یک بلوک CSS حیاتی را به‌صورت inline تعبیه کنید، یا قبل از اضافه کردن به پیکربندی bundle بررسی کنید یک استایل‌شیت چقدر کوچک می‌شود. اینجاست که یک فشرده‌ساز CSS مبتنی بر مرورگر مفید است: CSS را پیست کنید، خروجی فشرده‌شده را دریافت کنید، کپی کنید و ادامه دهید.

After · css
Before · css
.nav{display:flex;align-items:center;padding:1rem 2rem;background-color:#1e293b}.nav a{color:#e2e8f0;text-decoration:none;margin-right:1.5rem;transition:color .2s ease}.nav a:hover{color:#818cf8}
/* Main navigation styles */
.nav {
  display: flex;
  align-items: center;
  padding: 1rem 2rem;
  background-color: #1e293b;
}

/* Links inside nav */
.nav a {
  color: #e2e8f0;
  text-decoration: none;
  margin-right: 1.5rem;
  transition: color 0.2s ease;
}

.nav a:hover {
  color: #818cf8;
}

چرا از این فشرده‌ساز CSS استفاده کنیم؟

هر CSS دلخواهی را پیست کنید و در میلی‌ثانیه خروجی فشرده‌شده دریافت کنید. نیازی به پیکربندی ابزار build، دستورات CLI، یا ایجاد حساب کاربری نیست.

فشرده‌سازی فوری
خروجی همزمان با تایپ یا پیست کردن به‌روزرسانی می‌شود. نتیجه فشرده‌شده و میزان صرفه‌جویی در بایت را بلافاصله می‌بینید، بدون انتظار برای یک مرحله build.
🔒
پردازش با اولویت حریم خصوصی
تمام فشرده‌سازی به‌صورت محلی در مرورگر شما با JavaScript اجرا می‌شود. CSS شما هرگز دستگاه‌تان را ترک نمی‌کند و به هیچ سروری ارسال نمی‌شود.
📦
گزارش دقیق اندازه
اندازه اصلی، اندازه فشرده‌شده و درصد کاهش را در کنار هم ببینید. برای برآورد بهبود عملکرد پیش از تغییر پیکربندی پایپ‌لاین build مفید است.
📋
بدون نیاز به ورود
صفحه را باز کنید، CSS خود را پیست کنید، نتیجه را کپی کنید. بدون ثبت‌نام، بدون محدودیت نرخ، بدون قفل ویژگی. ابزار کامل در هر بار بازدید در دسترس است.

موارد استفاده فشرده‌ساز CSS

بهینه‌سازی عملکرد فرانت‌اند
CSS حیاتی را قبل از تعبیه‌کردن inline در عنصر head HTML فشرده کنید. CSS inline کوچک‌تر به معنای First Contentful Paint سریع‌تر است، به‌خصوص برای اتصالات موبایل.
قالب‌بندی ایمیل در بک‌اند
کلاینت‌های ایمیل استایل‌شیت‌های خارجی را نادیده می‌گیرند و محدودیت‌های سختی برای حجم دارند. CSS inline خود را فشرده کنید تا HTML ایمیل زیر محدودیت حجم (۱۰۲ کیلوبایت برای Gmail) بماند.
DevOps و تأیید Build
خروجی فشرده‌شده ابزار build خود را با این ابزار مقایسه کنید تا تأیید شود cssnano یا clean-css به‌درستی پیکربندی شده و نتایج بهینه تولید می‌کند.
بودجه اندازه در QA
یک استایل‌شیت ارائه‌دهنده را پیست کنید تا اندازه فشرده‌شده آن را با بودجه عملکردی خود مقایسه کنید. قبل از اضافه کردن به پروژه تعیین کنید آیا به tree-shaking یا جایگزینی نیاز دارد.
مهندسی داده و وب‌اسکرپینگ
هنگام استخراج CSS از صفحات کراول‌شده، آن را فشرده کنید تا تفاوت‌های فضای خالی بین منابع مختلف را قبل از مقایسه یا ذخیره‌سازی یکسان‌سازی کنید.
یادگیری بهینه‌سازی CSS
دانشجویان می‌توانند CSS را پیست کنند و دقیقاً ببینند فشرده‌ساز چه کاراکترهایی را حذف می‌کند. مقایسه ورودی و خروجی نشان می‌دهد کدام بخش‌های نحو CSS برای مرورگرها معنادار است و کدام‌ها صرفاً آرایشی هستند.

تکنیک‌های فشرده‌سازی CSS

یک فشرده‌ساز CSS چندین تبدیل برای کاهش حجم فایل اعمال می‌کند. هر کدام نوع خاصی از افزونگی در سورس را هدف می‌گیرند. جدول زیر تکنیک‌های اصلی و صرفه‌جویی معمول آن‌ها روی یک استایل‌شیت قالب‌بندی‌شده را نشان می‌دهد:

تکنیکتوضیحصرفه‌جویی معمول
Whitespace removalStrips spaces, tabs, and newlines between tokens15–25%
Comment strippingRemoves /* ... */ block comments5–15%
Zero shortening0px → 0, 0.5 → .51–3%
Shorthand colors#ffffff → #fff, #aabbcc → #abc1–2%
Semicolon removalDrops the last semicolon before }<1%
Quote removalfont-family: "Arial" → font-family: Arial<1%

درصد صرفه‌جویی بسته به ورودی متفاوت است. فایل‌هایی با کامنت زیاد از حذف کامنت بیشتر بهره می‌برند، در حالی که CSS از پیش فشرده‌شده کاهش کمتری می‌بیند. مطمئن‌ترین مزایا از حذف فضای خالی و بهینه‌سازی shorthand به‌دست می‌آیند. فشرده‌سازهای پیشرفته مانند cssnano همچنین سلکتورهای تکراری را ادغام، ویژگی‌های longhand را به shorthand تبدیل (مانند ترکیب margin-top، margin-right، margin-bottom و margin-left به margin) و اعلان‌های بازنویسی‌شده را حذف می‌کنند.

مینیفای‌کردن در مقابل فشرده‌سازی Gzip

فشرده‌سازی CSS و فشرده‌سازی فایل مکمل هستند، نه جایگزین یکدیگر. در لایه‌های مختلف عمل می‌کنند و روی هم انباشته می‌شوند:

فشرده‌سازی CSS (این ابزار)
در سطح نحو CSS عمل می‌کند. فضای خالی، کامنت‌ها را حذف و مقادیر shorthand را بازنویسی می‌کند. یک‌بار در زمان build اجرا می‌شود. خروجی CSS معتبری است که مرورگرها مستقیماً تجزیه می‌کنند. کاهش معمول: ۱۵ تا ۴۰ درصد حجم اصلی فایل.
فشرده‌سازی Gzip / Brotli
در سطح بایت با الگوریتم‌های فشرده‌سازی عمومی عمل می‌کند. توسط وب‌سرور در هر پاسخ اعمال می‌شود (یا در زمان استقرار از پیش فشرده می‌شود). روی هر نوع فایلی کار می‌کند. کاهش معمول: ۶۰ تا ۸۰ درصد از حجم CSS فشرده‌شده. استفاده از هر دو با هم کمترین حجم انتقال را به‌دست می‌دهد.

مثال‌های کد

نحوه فشرده‌سازی برنامه‌نویسی CSS در زبان‌ها و محیط‌های مختلف:

JavaScript (cssnano + PostCSS)
import postcss from 'postcss'
import cssnano from 'cssnano'

const input = `
.nav {
  display: flex;
  padding: 0px 1rem;
  color: #ffffff;
  /* TODO: update color */
}
`

const result = await postcss([cssnano]).process(input, { from: undefined })
console.log(result.css)
// → ".nav{display:flex;padding:0 1rem;color:#fff}"
Python (csscompressor)
import csscompressor

css = """
.nav {
  display: flex;
  padding: 0px 1rem;
  color: #ffffff;
  /* navigation styles */
}
"""

minified = csscompressor.compress(css)
print(minified)
# → ".nav{display:flex;padding:0 1rem;color:#fff}"
Go (tdewolff/minify)
package main

import (
	"fmt"
	"github.com/tdewolff/minify/v2"
	"github.com/tdewolff/minify/v2/css"
)

func main() {
	m := minify.New()
	m.AddFunc("text/css", css.Minify)

	input := ".nav { display: flex; padding: 0px 1rem; color: #ffffff; }"
	output, _ := m.String("text/css", input)
	fmt.Println(output)
	// → ".nav{display:flex;padding:0 1rem;color:#fff}"
}
CLI (cssnano / clean-css)
# Using cssnano via PostCSS CLI
npx postcss styles.css --use cssnano -o styles.min.css

# Using clean-css CLI
npx clean-css-cli styles.css -o styles.min.css

# Quick one-liner with Node.js
node -e "const CleanCSS=require('clean-css');console.log(new CleanCSS().minify('body { margin: 0px; }').styles)"
# → "body{margin:0}"

سؤالات متداول

تفاوت بین مینیفای کردن CSS و فشرده‌سازی (compression) آن چیست؟
مینیفای‌کردن سورس کد CSS را بازنویسی می‌کند تا کاراکترهای غیرضروری (فضای خالی، کامنت‌ها، نحو اضافی) را حذف کند در حالی که رفتار یکسان را حفظ می‌کند. فشرده‌سازی (gzip، Brotli) بایت‌های فایل را در یک قالب باینری فشرده‌تر در لایه انتقال رمزگذاری می‌کند. مینیفای‌کردن CSS فایل‌های کوچک‌تری روی دیسک ایجاد می‌کند؛ فشرده‌سازی انتقال بایت‌های ارسال‌شده از طریق HTTP را کاهش می‌دهد. بهترین روش اعمال هر دو است: ابتدا مینیفای کنید، سپس سرور خروجی مینیفای‌شده را فشرده کند.
آیا فشرده‌سازی CSS چیزی را خراب می‌کند؟
فشرده‌سازی استاندارد رفتار CSS را حفظ می‌کند. فضای خالی در داخل مقادیر رشته‌ای (مانند ویژگی‌های content) توسط تمام فشرده‌سازهای اصلی حفظ می‌شود. با این حال، بهینه‌سازی‌های تهاجمی مانند ادغام سلکتورها یا تغییر ترتیب ویژگی‌ها می‌توانند ویژگی‌مندی یا ترتیب بازنویسی را تغییر دهند. اگر از preset پیش‌فرض cssnano استفاده کنید، این تبدیل‌های پرخطر غیرفعال هستند. این ابزار فقط فشرده‌سازی امن انجام می‌دهد: حذف فضای خالی، حذف کامنت، و بهینه‌سازی shorthand.
CSS بعد از فشرده‌سازی چقدر کوچک می‌شود؟
کاهش معمول ۱۵ تا ۴۰ درصد حجم فایل قالب‌بندی‌شده اصلی است. فایل‌های با کامنت زیاد و فضای خالی سخاوتمندانه به انتهای بالای این بازه می‌رسند. CSS از پیش فشرده‌ای که بدون کامنت نوشته شده ممکن است فقط ۱۰ تا ۱۵ درصد کوچک شود. صرفه‌جویی دقیق به سبک کدنویسی، تراکم کامنت و استفاده از ویژگی‌های longhand که می‌توانند به shorthand تبدیل شوند بستگی دارد.
آیا باید CSS را دستی فشرده کنم یا از ابزار build استفاده کنم؟
برای buildهای محیط تولید، همیشه از ابزار build استفاده کنید (PostCSS با cssnano، esbuild، یا webpack با css-minimizer-webpack-plugin). فشرده‌سازی خودکار در هر build اجرا می‌شود و تمام فایل‌ها را پوشش می‌دهد. یک فشرده‌ساز مبتنی بر مرورگر برای کارهای موردی مفید است: تعبیه یک قطعه CSS حیاتی، بررسی حجم فشرده‌شده یک استایل‌شیت ارائه‌دهنده، یا فشرده‌سازی یک نمونه اولیه سریع قبل از اشتراک‌گذاری.
آیا می‌توانم SCSS یا LESS را با این ابزار فشرده کنم؟
این ابزار CSS استاندارد را فشرده می‌کند. SCSS و LESS زبان‌های پیش‌پردازنده هستند که به CSS کامپایل می‌شوند. ابتدا SCSS یا LESS خود را به CSS کامپایل کنید (با استفاده از sass یا lessc)، سپس خروجی کامپایل‌شده را اینجا پیست کنید. فشرده‌سازی نحو خام SCSS ممکن است کامنت‌هایی که رفتار کامپایل را کنترل می‌کنند را حذف کند، مانند کامنت‌های //! preserve یا دستورات @use.
آیا CSS فشرده‌شده اشکال‌زدایی را سخت‌تر می‌کند؟
بله، CSS فشرده‌شده یک خط واحد بدون قالب‌بندی است که خواندن آن در DevTools را دشوار می‌کند. راه‌حل استاندارد source mapها هستند. ابزارهایی مانند PostCSS و esbuild فایل‌های .map تولید می‌کنند که به DevTools مرورگر اجازه می‌دهند سورس قالب‌بندی‌شده اصلی را نمایش دهند در حالی که مرورگر نسخه فشرده‌شده را بارگذاری می‌کند. برای اشکال‌زدایی در محیط تولید بدون source map، CSS فشرده‌شده را در یک قالب‌بند CSS پیست کنید تا خوانایی بازیابی شود.
تفاوت بین فشرده‌ساز CSS و compressor CSS چیست؟
در استفاده رایج، این اصطلاحات به‌جای یکدیگر به‌کار می‌روند. هر دو به حذف کاراکترهای غیرضروری از CSS برای کاهش حجم فایل اشاره دارند. برخی ابزارها از 'compressor' در نامشان استفاده می‌کنند (مانند csscompressor برای Python) اما فشرده‌سازی استاندارد انجام می‌دهند. کلمه 'compression' همچنین می‌تواند به رمزگذاری gzip/Brotli اشاره داشته باشد که یک فرآیند جداگانه در سطح سرور است. اگر 'CSS compressor' می‌بینید، تقریباً همیشه به معنای فشرده‌سازی CSS است، نه gzip.