ToolDeck

CSS মিনিফায়ার

হোয়াইটস্পেস ও কমেন্ট সরিয়ে CSS মিনিফাই করুন

একটি উদাহরণ চেষ্টা করুন

CSS ইনপুট

মিনিফাইড CSS

স্থানীয়ভাবে চলে · গোপন তথ্য পেস্ট করা নিরাপদ
মিনিফাইড CSS এখানে দেখা যাবে…

CSS মিনিফিকেশন কী?

CSS মিনিফিকেশন হলো একটি স্টাইলশিটের আচরণ পরিবর্তন না করে সমস্ত অপ্রয়োজনীয় বর্ণ সরিয়ে ফেলার প্রক্রিয়া। এর অর্থ হলো হোয়াইটস্পেস, লাইন ব্রেক, কমেন্ট এবং ট্রেলিং সেমিকোলন ও অপ্রয়োজনীয় কোটেশনের মতো বাড়তি সিনট্যাক্স ছেঁটে ফেলা। ব্রাউজার মিনিফাইড CSS-কে মূল ফরম্যাটের মতোই পার্স করে। W3C CSS Syntax Module ব্যাকরণ নির্ধারণ করে; টোকেনের মধ্যে হোয়াইটস্পেস অপশনাল, শুধুমাত্র যেখানে এটি আইডেন্টিফায়ার আলাদা করে সেখান ছাড়া। মিনিফিকেশন এই সুযোগ ব্যবহার করে সবকিছু ন্যূনতম প্রয়োজনীয় বর্ণে সংকুচিত করে।

একটি অনলাইন CSS মিনিফায়ার আপনার ফরম্যাট করা স্টাইলশিট নিয়ে ট্রান্সফার আকারের জন্য অপ্টিমাইজড একটি সংক্ষিপ্ত সংস্করণ তৈরি করে। সাধারণ সাশ্রয় ১৫% থেকে ৪০% পর্যন্ত হয়, যা উৎস ফাইলে কতটা হোয়াইটস্পেস এবং কতটি কমেন্ট আছে তার উপর নির্ভর করে। একটি ৫০ KB স্টাইলশিটের ক্ষেত্রে এর অর্থ প্রতিটি পেজ লোডে নেটওয়ার্কে ৭–২০ KB কম বাইট পাঠানো। সার্ভারে gzip বা Brotli কম্প্রেশনের সাথে মিলিয়ে, মিনিফিকেশন চূড়ান্ত ট্রান্সফার আকার আরও কমায়, কারণ ইতিমধ্যে মিনিফাইড CSS কম্প্রেস করলে ফরম্যাট করা মূলটির চেয়ে ছোট আউটপুট পাওয়া যায়।

মিনিফিকেশন ফ্রন্টেন্ড বিল্ড পাইপলাইনে একটি আদর্শ ধাপ। cssnano, clean-css এবং esbuild-এর মতো টুল বিল্ডের অংশ হিসেবে মিনিফিকেশন চালায়। তবে ডেভেলপমেন্টের সময়, আপনার প্রায়ই একটি একক স্নিপেট পরীক্ষার জন্য মিনিফাই করতে হয়, একটি গুরুত্বপূর্ণ CSS ব্লক ইনলাইন করতে হয়, বা বান্ডেল কনফিগে যোগ করার আগে একটি স্টাইলশিট কতটা সংকুচিত হয় তা যাচাই করতে হয়। এখানেই একটি ব্রাউজার-ভিত্তিক CSS মিনিফায়ার কাজে আসে: CSS পেস্ট করুন, মিনিফাইড আউটপুট পান, কপি করুন এবং এগিয়ে যান।

Before · css
After · css
/* 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;
}
.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}

এই CSS মিনিফায়ার কেন ব্যবহার করবেন?

যেকোনো CSS পেস্ট করুন এবং মিলিসেকেন্ডের মধ্যে মিনিফাইড আউটপুট পান। কোনো বিল্ড টুল কনফিগারেশন নেই, কোনো CLI কমান্ড নেই, কোনো অ্যাকাউন্ট তৈরি করতে হবে না।

তাৎক্ষণিক মিনিফিকেশন
আপনি টাইপ বা পেস্ট করার সাথে সাথে আউটপুট আপডেট হয়। কোনো বিল্ড স্টেপের জন্য অপেক্ষা ছাড়াই মিনিফাইড ফলাফল এবং বাইট সাশ্রয় তাৎক্ষণিকভাবে দেখতে পাবেন।
🔒
প্রাইভেসি ফার্স্ট
সমস্ত মিনিফিকেশন JavaScript ব্যবহার করে আপনার ব্রাউজারেই স্থানীয়ভাবে চলে। আপনার CSS কখনো আপনার ডিভাইস ছাড়ে না এবং কোনো সার্ভারে আপলোড হয় না।
📦
সঠিক আকার রিপোর্টিং
মূল আকার, মিনিফাইড আকার এবং শতাংশ হ্রাস পাশাপাশি দেখুন। বিল্ড পাইপলাইন পরিবর্তনে প্রতিশ্রুতি দেওয়ার আগে পারফরম্যান্স উন্নতি অনুমান করতে সহায়ক।
📋
লগইন প্রয়োজন নেই
পৃষ্ঠাটি খুলুন, আপনার CSS পেস্ট করুন, ফলাফল কপি করুন। কোনো সাইন-আপ নেই, কোনো রেট সীমা নেই, কোনো ফিচার গেট নেই। প্রতিটি ভিজিটে পূর্ণ টুলটি পাওয়া যায়।

CSS মিনিফায়ারের ব্যবহারের ক্ষেত্র

ফ্রন্টেন্ড পারফরম্যান্স অপ্টিমাইজেশন
আপনার HTML-এর head এলিমেন্টে ইনলাইন করার আগে গুরুত্বপূর্ণ CSS মিনিফাই করুন। ছোট ইনলাইন CSS মানে দ্রুততর First Contentful Paint, বিশেষত মোবাইল সংযোগে।
ব্যাকেন্ড ইমেইল টেমপ্লেটিং
ইমেইল ক্লায়েন্ট বাহ্যিক স্টাইলশিট উপেক্ষা করে এবং কঠোর আকার সীমা রাখে। ইমেইল HTML ক্লিপিং থ্রেশহোল্ডের (Gmail-এর জন্য ১০২ KB) মধ্যে রাখতে আপনার ইনলাইন CSS মিনিফাই করুন।
DevOps ও বিল্ড যাচাই
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%

সাশ্রয়ের শতাংশ ইনপুটের উপর নির্ভর করে। ভারীভাবে মন্তব্য করা ফাইলগুলো কমেন্ট স্ট্রিপিং থেকে বেশি উপকৃত হয়, আর ইতিমধ্যে-সংক্ষিপ্ত ফাইলগুলো কম সাশ্রয় দেখে। সবচেয়ে নির্ভরযোগ্য সুবিধা হোয়াইটস্পেস অপসারণ ও শর্টহ্যান্ড অপ্টিমাইজেশন থেকে আসে। cssnano-র মতো উন্নত মিনিফায়ার ডুপ্লিকেট সিলেক্টর মার্জ করে, লংহ্যান্ড প্রপার্টি শর্টহ্যান্ডে ভাঁজ করে (margin-top + margin-right + margin-bottom + margin-left → margin) এবং ওভাররাইড হওয়া ডিক্লারেশন সরায়।

মিনিফিকেশন বনাম Gzip কম্প্রেশন

মিনিফিকেশন ও কম্প্রেশন পরিপূরক, পরস্পরের বিকল্প নয়। এগুলো ভিন্ন স্তরে কাজ করে এবং একে অপরের উপর স্তরবদ্ধ হয়:

CSS মিনিফিকেশন (এই টুল)
CSS সিনট্যাক্স স্তরে কাজ করে। হোয়াইটস্পেস, কমেন্ট সরায় এবং শর্টহ্যান্ড মান পুনরায় লেখে। বিল্ড সময়ে একবার চলে। আউটপুটটি বৈধ CSS যা ব্রাউজার সরাসরি পার্স করে। সাধারণ হ্রাস: মূল ফাইলের ১৫–৪০%।
Gzip / Brotli কম্প্রেশন
সাধারণ-উদ্দেশ্য কম্প্রেশন অ্যালগরিদম ব্যবহার করে বাইট স্তরে কাজ করে। প্রতিটি রেসপন্সে ওয়েব সার্ভার প্রয়োগ করে (বা ডিপ্লয় সময়ে প্রি-কম্প্রেস করা)। যেকোনো ফাইলের ধরনে কাজ করে। সাধারণ হ্রাস: মিনিফাইড আকারের ৬০–৮০%। উভয় একসাথে ব্যবহার করলে সবচেয়ে ছোট ট্রান্সফার আকার পাওয়া যায়।

কোড উদাহরণ

বিভিন্ন ভাষা ও পরিবেশে প্রোগ্রামেটিক্যালি 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 মিনিফিকেশন ও CSS কম্প্রেশনের মধ্যে পার্থক্য কী?
মিনিফিকেশন CSS সোর্স কোড পুনরায় লিখে অপ্রয়োজনীয় বর্ণ (হোয়াইটস্পেস, কমেন্ট, অতিরিক্ত সিনট্যাক্স) সরায়, কিন্তু আচরণ একই রাখে। কম্প্রেশন (gzip, Brotli) ট্রান্সপোর্ট স্তরে ফাইলের বাইটগুলো একটি আরও সংক্ষিপ্ত বাইনারি ফরম্যাটে এনকোড করে। মিনিফিকেশন ডিস্কে ছোট CSS ফাইল তৈরি করে; কম্প্রেশন HTTP-তে পাঠানো বাইট কমায়। সর্বোত্তম অভ্যাস হলো উভয় প্রয়োগ করা: প্রথমে মিনিফাই করুন, তারপর সার্ভারকে মিনিফাইড আউটপুট কম্প্রেস করতে দিন।
CSS মিনিফাই করলে কি কিছু ভেঙে যায়?
আদর্শ মিনিফিকেশন CSS আচরণ বজায় রাখে। content প্রপার্টির মতো স্ট্রিং মানের ভেতরে হোয়াইটস্পেস সমস্ত প্রধান মিনিফায়ার সংরক্ষণ করে। তবে সিলেক্টর মার্জ করা বা প্রপার্টি পুনর্বিন্যাসের মতো আগ্রাসী অপ্টিমাইজেশন স্পেসিফিসিটি বা ওভাররাইড ক্রম পরিবর্তন করতে পারে। cssnano-র ডিফল্ট প্রিসেট ব্যবহার করলে এই ঝুঁকিপূর্ণ রূপান্তরগুলো নিষ্ক্রিয় থাকে। এই টুল কেবল নিরাপদ মিনিফিকেশন করে: হোয়াইটস্পেস অপসারণ, কমেন্ট স্ট্রিপিং এবং শর্টহ্যান্ড অপ্টিমাইজেশন।
মিনিফিকেশনের পরে CSS কতটা ছোট হয়?
সাধারণ হ্রাস হলো মূল ফরম্যাট করা ফাইলের ১৫–৪০%। ভালোভাবে মন্তব্য করা এবং উদার হোয়াইটস্পেসসহ ফাইলগুলো সেই পরিসরের উপরের দিকে থাকে। কমেন্ট ছাড়া ইতিমধ্যে-সংক্ষিপ্ত CSS কেবল ১০–১৫% সংকুচিত হতে পারে। সঠিক সাশ্রয় কোডিং স্টাইল, কমেন্ট ঘনত্ব এবং উৎসে লংহ্যান্ড প্রপার্টি ব্যবহার করা হয়েছে কিনা তার উপর নির্ভর করে।
CSS ম্যানুয়ালি মিনিফাই করব নাকি বিল্ড টুল ব্যবহার করব?
প্রোডাকশন বিল্ডের জন্য সর্বদা একটি বিল্ড টুল ব্যবহার করুন (cssnano সহ PostCSS, esbuild, বা webpack-এর css-minimizer-webpack-plugin)। স্বয়ংক্রিয় মিনিফিকেশন প্রতিটি বিল্ডে চলে এবং সমস্ত ফাইল কভার করে। একবারের কাজের জন্য ব্রাউজার-ভিত্তিক মিনিফায়ার উপযোগী: একটি গুরুত্বপূর্ণ CSS স্নিপেট ইনলাইন করা, একটি ভেন্ডার স্টাইলশিটের মিনিফাইড আকার যাচাই করা, বা শেয়ার করার আগে একটি দ্রুত প্রোটোটাইপ মিনিফাই করা।
এই টুল দিয়ে কি SCSS বা LESS মিনিফাই করা যাবে?
এই টুল আদর্শ CSS মিনিফাই করে। SCSS ও LESS হলো প্রিপ্রসেসর ভাষা যা CSS-এ কম্পাইল হয়। আপনার SCSS বা LESS প্রথমে CSS-এ কম্পাইল করুন (sass বা lessc ব্যবহার করে), তারপর কম্পাইল করা আউটপুট এখানে পেস্ট করুন। Raw SCSS সিনট্যাক্স মিনিফাই করলে কম্পাইলেশন আচরণ নিয়ন্ত্রণকারী কমেন্ট বাদ পড়তে পারে, যেমন //! preserve কমেন্ট বা @use অ্যানোটেশন।
মিনিফাইড CSS কি ডিবাগ করা কঠিন?
হ্যাঁ, মিনিফাইড CSS একটি একক লাইনে থাকায় DevTools-এ পড়া কঠিন। আদর্শ সমাধান হলো সোর্স ম্যাপ। PostCSS ও esbuild-এর মতো বিল্ড টুল .map ফাইল তৈরি করে যা ব্রাউজার DevTools-কে মিনিফাইড সংস্করণ লোড করার সময়ও মূল ফরম্যাট করা উৎস প্রদর্শন করতে দেয়। সোর্স ম্যাপ ছাড়া প্রোডাকশন ডিবাগিংয়ের জন্য, পাঠযোগ্যতা পুনরুদ্ধার করতে মিনিফাইড CSS একটি CSS ফরম্যাটারে পেস্ট করুন।
CSS মিনিফায়ার ও CSS কম্প্রেসরের মধ্যে পার্থক্য কী?
সাধারণ ব্যবহারে শব্দগুলো পরস্পর পরিবর্তনযোগ্য। উভয়ই ফাইলের আকার কমাতে CSS থেকে অপ্রয়োজনীয় বর্ণ সরানোকে বোঝায়। কিছু টুল তাদের নামে 'কম্প্রেসর' ব্যবহার করে (যেমন Python-এর csscompressor) কিন্তু আদর্শ মিনিফিকেশনই করে। 'কম্প্রেশন' শব্দটি gzip/Brotli এনকোডিংকেও বোঝাতে পারে, যা একটি পৃথক সার্ভার-স্তরের প্রক্রিয়া। 'CSS কম্প্রেসর' দেখলে এর প্রায় সবসময় মিনিফিকেশন বোঝায়, gzip নয়।