ToolDeck

HTML মিনিফায়ার

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

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

HTML ইনপুট

মিনিফাইড HTML

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

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

HTML মিনিফিকেশন হলো একটি HTML ডকুমেন্টের আকার কমানোর প্রক্রিয়া, যেখানে ব্রাউজার যেভাবে রেন্ডার করে তা অপরিবর্তিত থাকে। একটি HTML মিনিফায়ার শুধুমাত্র ডেভেলপারের পাঠযোগ্যতার জন্য থাকা অক্ষরগুলো সরিয়ে দেয়: ট্যাগের মাঝে হোয়াইটস্পেস, কমেন্ট, ঐচ্ছিক ক্লোজিং ট্যাগ এবং অপ্রয়োজনীয় অ্যাট্রিবিউট মান। আউটপুট কার্যত উৎসের সমতুল্য কিন্তু বাইট আকারে ছোট, যার মানে দ্রুত ডাউনলোড এবং ব্যবহারকারীদের জন্য দ্রুত টাইম-টু-ফার্স্ট-পেইন্ট।

ব্রাউজার HTML-কে একটি DOM ট্রিতে পার্স করে এবং সেই প্রক্রিয়ায় বেশিরভাগ হোয়াইটস্পেস বাতিল করে দেয়। দুটি div ট্যাগের মাঝে স্পেস ও লাইন ব্রেকের ক্রম রেন্ডার করা পৃষ্ঠায় কোনো দৃশ্যমান প্রভাব ফেলে না। কমেন্টও পার্সার উপেক্ষা করে। মিনিফিকেশন এই নিয়মগুলো ব্যবহার করে, পার্সার যা বাতিল করত তা ছেঁটে ফেলে, যাতে তা কখনো নেটওয়ার্কে পাঠাতে না হয়।

HTML মিনিফিকেশন থেকে সাশ্রয় ডকুমেন্টভেদে পরিবর্তিত হয়। প্রচুর কমেন্ট সহ টেমপ্লেট, গভীর ইন্ডেন্টেশনসহ সার্ভার-রেন্ডার করা পৃষ্ঠা এবং ইনলাইন স্টাইল সহ CMS আউটপুট প্রায়ই শুধু মিনিফিকেশন থেকে ১৫-৩০% আকার হ্রাস পায়। ছোট ডকুমেন্টের জন্য পরম সাশ্রয় সামান্য, তবে উচ্চ-ট্র্যাফিক সাইটে প্রতিটি পৃষ্ঠা লোডে কয়েক কিলোবাইটও লক্ষ লক্ষ রিকোয়েস্টে প্রকৃত ব্যান্ডউইথ সাশ্রয়ে পরিণত হয়।

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

আপনার HTML পেস্ট করুন এবং তাৎক্ষণিকভাবে মিনিফাইড আউটপুট পান। কোনো বিল্ড টুল ইনস্টল করতে হবে না, কোনো কনফিগারেশন ফাইল নেই, কোনো অ্যাকাউন্ট নেই।

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

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

ফ্রন্টেন্ড ডেভেলপমেন্ট
প্রোডাকশনে ডিপ্লয় করার আগে HTML টেমপ্লেট মিনিফাই করুন। সার্ভার-রেন্ডার করা পৃষ্ঠা, স্ট্যাটিক সাইট জেনারেটর আউটপুট বা সিঙ্গেল-পেজ অ্যাপ্লিকেশন শেলের পেলোড কমান।
ব্যাকেন্ড ইঞ্জিনিয়ারিং
Django, Rails বা Laravel-এর মতো সার্ভার-সাইড ফ্রেমওয়ার্ক দ্বারা তৈরি HTML রেসপন্স থেকে ক্লায়েন্টে পাঠানোর আগে কমেন্ট ও হোয়াইটস্পেস সরিয়ে ফেলুন।
DevOps ও CI পাইপলাইন
আপনার বিল্ড পাইপলাইনে একটি HTML মিনিফিকেশন ধাপ যোগ করুন। স্টেজিং বা প্রোডাকশনে পুশ করার আগে নিশ্চিত করুন যে মিনিফিকেশনের পরে আউটপুট সঠিকভাবে রেন্ডার হচ্ছে।
QA ও পরীক্ষা
অপ্রত্যাশিত কাঠামোগত পরিবর্তন পরীক্ষা করতে দুটি বিল্ডের মিনিফাইড আউটপুট তুলনা করুন। মিনিফিকেশন হোয়াইটস্পেস নর্মালাইজ করে, কাঠামোগত ডিফ পরিষ্কার করে।
ইমেইল টেমপ্লেট অপ্টিমাইজেশন
ইমেইল ক্লায়েন্ট HTML ইমেইলে আকারের সীমা আরোপ করে (Gmail ১০২ KB-এর বেশি বার্তা ক্লিপ করে)। সমস্ত কন্টেন্ট অক্ষুণ্ণ রেখে সীমার মধ্যে থাকতে ইমেইল টেমপ্লেট মিনিফাই করুন।
ওয়েব পারফরম্যান্স শেখা
শিক্ষার্থীরা HTML পেস্ট করে দেখতে পারেন কোন অংশগুলো মিনিফিকেশনে বাদ পড়ে। এটি শেখায় কোন অক্ষরগুলো ব্রাউজারের কাছে অর্থপূর্ণ এবং কোনগুলো শুধু সৌন্দর্যের জন্য।

HTML মিনিফিকেশনে কী সরানো হয়

একটি পূর্ণাঙ্গ HTML মিনিফায়ার হোয়াইটস্পেস অপসারণের বাইরেও বেশ কিছু রূপান্তর প্রয়োগ করে। নিচের সারণিতে সাধারণ কৌশলগুলো তালিকাভুক্ত করা হয়েছে, নিরাপদ (সবসময় প্রযোজ্য) থেকে সবচেয়ে আগ্রাসী (অন্ধভাবে প্রয়োগ করলে এজ কেস ভাঙতে পারে) পর্যন্ত ক্রমানুযায়ী।

কৌশলআগেপরে
Whitespace between tags<div> <p> text </p> </div><div><p>text</p></div>
HTML comments<!-- TODO: fix later -->(removed entirely)
Redundant attribute quotesclass="main"class=main
Boolean attribute valuesdisabled="disabled"disabled
Empty attribute valuesid=""(attribute removed)
Optional closing tags</li>, </td>, </p>(removed when safe)
Type on script/styletype="text/javascript"(removed — default)
Protocol in URLshttps://cdn.example.com//cdn.example.com

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

ডেভেলপাররা মাঝেমাঝে জিজ্ঞাসা করেন যে সার্ভার ইতিমধ্যে Gzip বা Brotli কম্প্রেশন প্রয়োগ করলে মিনিফিকেশন এখনো প্রয়োজনীয় কিনা। সংক্ষিপ্ত উত্তর: হ্যাঁ, এবং তারা একসাথে সবচেয়ে ভালো কাজ করে।

মিনিফিকেশন
টেক্সট স্তরে কাজ করে। পার্সার যে অক্ষরগুলো উপেক্ষা করে তা সরায়: কমেন্ট, হোয়াইটস্পেস, অপ্রয়োজনীয় অ্যাট্রিবিউট। যেকোনো কম্প্রেশন প্রয়োগের আগে কাঁচা ফাইলের আকার কমায়। বিল্ড সময়ে একবার ঘটে।
Gzip / Brotli কম্প্রেশন
বাইট স্তরে কাজ করে। পুনরাবৃত্তি বাইট প্যাটার্ন খুঁজে বের করে এবং ছোট রেফারেন্স দিয়ে এনকোড করে। প্রতিটি HTTP রেসপন্সে ওয়েব সার্ভার প্রয়োগ করে। ব্রাউজার পৌঁছানোর পর ডিকম্প্রেস করে।

মিনিফিকেশন Gzip যে ইনপুট প্রসেস করে তা কমিয়ে দেয়, ফলে কম্প্রেস করা আউটপুটও ছোট হয়। Google-এর PageSpeed গাইডলাইন উভয় প্রয়োগের সুপারিশ করে। একটি সাধারণ পৃষ্ঠায়, মিনিফিকেশন কাঁচা আকারের ১৫-২৫% সাশ্রয় করে এবং Gzip ফলাফলকে আরো ৬০-৮০% কম্প্রেস করে। একত্রে, মোট ট্রান্সফার আকার মিনিফাই না করা, কম্প্রেস না করা মূল ডকুমেন্টের ১০-২০%-এ নেমে আসতে পারে।

কোড উদাহরণ

নিচে চারটি পরিবেশে HTML মিনিফিকেশনের কার্যকরী উদাহরণ দেওয়া হয়েছে। প্রতিটি উদাহরণ কমেন্ট সরায় এবং হোয়াইটস্পেস সংকুচিত করে।

JavaScript (html-minifier-terser)
import { minify } from 'html-minifier-terser'

const html = `
  <div class="card">
    <!-- user profile -->
    <p>  Hello, world!  </p>
  </div>
`

const result = await minify(html, {
  collapseWhitespace: true,
  removeComments: true,
  removeRedundantAttributes: true,
  removeEmptyAttributes: true,
})
// → '<div class="card"><p>Hello, world!</p></div>'
Python (htmlmin)
import htmlmin

html = """
<div class="card">
  <!-- user profile -->
  <p>  Hello, world!  </p>
</div>
"""

result = htmlmin.minify(html, remove_comments=True, remove_empty_space=True)
# → '<div class="card"><p>Hello, world!</p></div>'
Go (tdewolff/minify)
package main

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

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

    input := `<div class="card">
  <!-- user profile -->
  <p>  Hello, world!  </p>
</div>`

    result, _ := m.String("text/html", input)
    fmt.Println(result)
    // → <div class=card><p>Hello, world!</div>
}
CLI (html-minifier-terser)
# Install globally
npm install -g html-minifier-terser

# Minify a file
html-minifier-terser --collapse-whitespace --remove-comments input.html -o output.html

# Pipe from stdin
cat index.html | html-minifier-terser --collapse-whitespace --remove-comments

# With all common optimizations
html-minifier-terser \
  --collapse-whitespace \
  --remove-comments \
  --remove-redundant-attributes \
  --remove-empty-attributes \
  --minify-css true \
  --minify-js true \
  input.html -o output.min.html

সচরাচর জিজ্ঞাসিত প্রশ্ন

HTML মিনিফিকেশন কি আমার পৃষ্ঠা ভেঙে দিতে পারে?
নিরাপদ মিনিফিকেশন (কমেন্ট সরানো ও হোয়াইটস্পেস সংকুচিত করা) ব্রাউজার রেন্ডারিং পরিবর্তন করে না। ঐচ্ছিক ক্লোজিং ট্যাগ সরানো বা বুলিয়ান অ্যাট্রিবিউট সংকুচিত করার মতো আগ্রাসী বিকল্পগুলো HTML স্পেসিফিকেশনের অংশ এবং সমস্ত আধুনিক ব্রাউজারে কাজ করে। একটি ক্ষেত্র লক্ষ রাখার মতো হলো pre ও textarea কন্টেন্ট, যেখানে হোয়াইটস্পেস গুরুত্বপূর্ণ। ভালো মিনিফায়ার এই এলিমেন্টগুলোর ভেতরে হোয়াইটস্পেস সংরক্ষণ করে।
মিনিফিকেশনের পরে HTML কতটা ছোট হয়?
সাধারণ সাশ্রয় মূল ফাইলের আকারের ১০% থেকে ৩০%, উৎসে কতটা হোয়াইটস্পেস এবং কতগুলো কমেন্ট আছে তার উপর নির্ভর করে। ভারীভাবে ইন্ডেন্টেড, প্রচুর কমেন্টসহ টেমপ্লেটগুলো সর্বাধিক সুবিধা পায়। ন্যূনতম ফরম্যাটিং সহ ইতিমধ্যে-কম্প্যাক্ট HTML মাত্র ৫-৮% সংকুচিত হতে পারে।
আমি ইতিমধ্যে Gzip ব্যবহার করলে কি HTML মিনিফাই করা উচিত?
হ্যাঁ। মিনিফিকেশন ও কম্প্রেশন ভিন্ন স্তরে কাজ করে। মিনিফিকেশন অপ্রয়োজনীয় টেক্সট অক্ষর সরায়; Gzip পুনরাবৃত্তি বাইট প্যাটার্ন খুঁজে বের করে। প্রথমে মিনিফাই করা মানে Gzip-এর কম ডেটা প্রসেস করতে হয়, ফলে ছোট কম্প্রেস করা আউটপুট পাওয়া যায়। Google উভয় প্রয়োগের সুপারিশ করে।
ইনলাইন JavaScript সহ HTML মিনিফাই করা কি নিরাপদ?
একটি মৌলিক হোয়াইটস্পেস-সংকুচিত মিনিফায়ার script ট্যাগের ভেতরের কন্টেন্ট পরিবর্তন করে না। --minify-js বিকল্পসহ মিনিফায়ারগুলো JS মিনিফায়ার ব্যবহার করে ইনলাইন JavaScript-ও কম্প্রেস করবে। যদি আপনার ইনলাইন স্ক্রিপ্ট উল্লেখযোগ্য হোয়াইটস্পেসের উপর নির্ভর করে (বিরল), আউটপুট পরীক্ষা করুন। বেশিরভাগ ইনলাইন স্ক্রিপ্ট মিনিফিকেশনের পরে ঠিকঠাক কাজ করে।
HTML মিনিফিকেশন ও HTML কম্প্রেশনের মধ্যে পার্থক্য কী?
মিনিফিকেশন হলো একটি বিল্ড-টাইম টেক্সট রূপান্তর যা অপ্রয়োজনীয় অক্ষর সরিয়ে দেয়। কম্প্রেশন (Gzip, Brotli) হলো একটি সার্ভার-টাইম বাইনারি এনকোডিং যা HTTP রেসপন্স সংকুচিত করে। মিনিফিকেশন অপরিবর্তনীয় (কমেন্টগুলো চলে যায়), যেখানে কম্প্রেশন ব্রাউজারে পৌঁছানোর পর ডিকম্প্রেস হয়।
মিনিফিকেশন কি SEO-কে প্রভাবিত করে?
না। সার্চ ইঞ্জিন ক্রলাররা ব্রাউজারের মতোই DOM পার্স করে। তারা হোয়াইটস্পেস ও কমেন্ট উপেক্ষা করে। মিনিফিকেশন DOM কাঠামো পরিবর্তন করে না, তাই সার্চ ইঞ্জিন আপনার পৃষ্ঠা কীভাবে ইন্ডেক্স করে তাতে কোনো প্রভাব নেই। ছোট HTML থেকে দ্রুত পৃষ্ঠা লোড সময় Core Web Vitals সিগন্যালের মাধ্যমে পরোক্ষভাবে র‌্যাংকিং উন্নত করতে পারে।
HTML মিনিফিকেশন CSS বা JavaScript মিনিফিকেশনের সাথে কীভাবে তুলনীয়?
CSS ও JavaScript মিনিফায়ার ভেরিয়েবলের নাম পরিবর্তন করে, ডেড কোড সরায় এবং সেই ভাষাগুলোর জন্য নির্দিষ্ট অপ্টিমাইজেশন সম্পাদন করে। HTML মিনিফায়ারগুলো সহজ কারণ HTML-এ অপ্টিমাইজ করার মতো কোনো ভেরিয়েবল বা কার্যকরযোগ্য লজিক নেই। HTML মিনিফিকেশন হোয়াইটস্পেস, কমেন্ট এবং অপ্রয়োজনীয় অ্যাট্রিবিউট সিনট্যাক্সের উপর দৃষ্টি নিবদ্ধ করে।