Skip to content

Markdown কীভাবে কাজ করে

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

মৌলিক কার্যপ্রণালী

Markdown কার্যপ্রণালীকে নিম্নলিখিত ধাপে সংক্ষেপিত করা যেতে পারে:

Markdown সোর্স ফাইল (.md) → Markdown পার্সার → HTML ডকুমেন্ট → ব্রাউজার রেন্ডারিং

১. Markdown সোর্স ফাইল লেখা

আপনি যেকোনো টেক্সট এডিটর ব্যবহার করে একটি .md ফাইল তৈরি করেন এবং Markdown সিনট্যাক্স ব্যবহার করে কন্টেন্ট লেখেন:

markdown
# আমার ডকুমেন্ট

এটি একটি **গুরুত্বপূর্ণ** অনুচ্ছেদ।

## তালিকা উদাহরণ

- আইটেম ১
- আইটেম ২
- আইটেম ৩

২. Markdown পার্সার প্রসেসিং

পার্সারটি Markdown ফাইলটি পড়ে, সিনট্যাক্স উপাদানগুলো চিহ্নিত করে এবং সেগুলোকে সংশ্লিষ্ট HTML-এ রূপান্তর করে:

html
<h1>আমার ডকুমেন্ট</h1>
<p>এটি একটি <strong>গুরুত্বপূর্ণ</strong> অনুচ্ছেদ।</p>
<h2>তালিকা উদাহরণ</h2>
<ul>
  <li>আইটেম ১</li>
  <li>আইটেম ২</li>
  <li>আইটেম ৩</li>
</ul>

৩. ব্রাউজার রেন্ডারিং

উৎপন্ন HTML ব্রাউজারে ফরম্যাট করা ডকুমেন্ট হিসেবে প্রদর্শিত হয়।

পার্সার কীভাবে কাজ করে

লেক্সিক্যাল বিশ্লেষণ

পার্সার প্রথমে লেক্সিক্যাল বিশ্লেষণ সম্পাদন করে, Markdown টেক্সটকে টোকেনে বিভক্ত করে:

  • # একটি হেডিং টোকেন হিসেবে চিহ্নিত
  • **text** একটি বোল্ড টোকেন হিসেবে চিহ্নিত
  • - item একটি লিস্ট আইটেম টোকেন হিসেবে চিহ্নিত

সিনট্যাক্স পার্সিং

তারপর এটি সিনট্যাক্স পার্সিং সম্পাদন করে একটি Abstract Syntax Tree (AST) তৈরি করতে:

Document
├── Heading (level 1): "আমার ডকুমেন্ট"
├── Paragraph
│   ├── Text: "এটি একটি"
│   ├── Bold: "গুরুত্বপূর্ণ"
│   └── Text: "অনুচ্ছেদ।"
├── Heading (level 2): "তালিকা উদাহরণ"
└── Unordered List
    ├── List Item: "আইটেম ১"
    ├── List Item: "আইটেম ২"
    └── List Item: "আইটেম ৩"

HTML জেনারেশন

অবশেষে, সিনট্যাক্স ট্রি ট্রাভার্স করে সংশ্লিষ্ট HTML আউটপুট তৈরি করা হয়।

মূলধারার পার্সার

CommonMark

  • স্ট্যান্ডার্ড স্পেসিফিকেশন - একটি ঐক্যবদ্ধ Markdown পার্সিং স্ট্যান্ডার্ড প্রদান করে
  • কঠোরভাবে সংজ্ঞায়িত - বিভিন্ন ইমপ্লিমেন্টেশনের মধ্যে অস্পষ্টতা দূর করে
  • ব্যাপকভাবে সমর্থিত - একাধিক পার্সার দ্বারা গৃহীত

GitHub Flavored Markdown (GFM)

CommonMark এর উপর ভিত্তি করে, অতিরিক্ত বৈশিষ্ট্য:

  • টেবিল সমর্থন
  • স্ট্রিকথ্রু
  • টাস্ক লিস্ট
  • অটোলিঙ্ক সনাক্তকরণ
  • সিনট্যাক্স-হাইলাইটেড কোড ব্লক

অন্যান্য পার্সার

পার্সারভাষাবৈশিষ্ট্য
markedJavaScriptদ্রুত, হালকা
markdown-itJavaScriptপ্লাগযোগ্য, অত্যন্ত এক্সটেন্সিবল
Python-MarkdownPythonবৈশিষ্ট্য-সমৃদ্ধ, প্লাগইন সিস্টেম
kramdownRubyএকাধিক আউটপুট ফরম্যাট সমর্থন করে
PandocHaskellসার্বজনীন ডকুমেন্ট কনভার্টার

রেন্ডারিং ইঞ্জিন

ক্লায়েন্ট-সাইড রেন্ডারিং

ব্রাউজারে রিয়েল-টাইমে Markdown পার্স করুন:

javascript
// marked.js ব্যবহার করে
const html = marked.parse('# Hello World');
document.body.innerHTML = html;

সুবিধা:

  • সার্ভার প্রসেসিংয়ের প্রয়োজন নেই
  • রিয়েল-টাইম প্রিভিউ
  • সার্ভার লোড হ্রাস করে

অসুবিধা:

  • JavaScript এর উপর নির্ভরশীল
  • SEO-বান্ধব নয়
  • প্রাথমিক লোড ধীর

সার্ভার-সাইড রেন্ডারিং

সার্ভারে আগে থেকে HTML তৈরি করুন:

javascript
// Node.js উদাহরণ
const fs = require('fs');
const marked = require('marked');

const markdown = fs.readFileSync('document.md', 'utf8');
const html = marked.parse(markdown);

সুবিধা:

  • SEO-বান্ধব
  • দ্রুত লোডিং
  • ক্লায়েন্ট-সাইড JavaScript এর উপর নির্ভর করে না

অসুবিধা:

  • সার্ভার প্রসেসিং ওভারহেড
  • জটিল ক্যাশে ম্যানেজমেন্ট

স্ট্যাটিক সাইট জেনারেশন

বিল্ড টাইমে সমস্ত পেজ আগে থেকে তৈরি করুন:

bash
# VitePress ব্যবহার করে
npm run build

সুবিধা:

  • দ্রুততম লোডিং স্পিড
  • সেরা SEO
  • উচ্চ নিরাপত্তা
  • সহজ ডেপ্লয়মেন্ট

অসুবিধা:

  • ডায়নামিক কন্টেন্টের জন্য সীমিত সমর্থন
  • দীর্ঘতর বিল্ড সময়

এক্সটেনশন মেকানিজম

প্লাগইন সিস্টেম

অনেক পার্সার প্লাগইন এক্সটেনশন সমর্থন করে:

javascript
// markdown-it প্লাগইন উদাহরণ
const md = require('markdown-it')()
  .use(require('markdown-it-footnote'))
  .use(require('markdown-it-deflist'))
  .use(require('markdown-it-abbr'));

কাস্টম রেন্ডারার

javascript
// কাস্টম লিঙ্ক রেন্ডারার
const renderer = new marked.Renderer();
renderer.link = function(href, title, text) {
  return `<a href="${href}" target="_blank">${text}</a>`;
};

কার্যক্ষমতা অপ্টিমাইজেশন

ক্যাশিং স্ট্র্যাটেজি

javascript
const cache = new Map();

function parseMarkdown(content) {
  const hash = generateHash(content);
  if (cache.has(hash)) {
    return cache.get(hash);
  }
  
  const result = marked.parse(content);
  cache.set(hash, result);
  return result;
}

লেজি লোডিং

javascript
// শুধুমাত্র দৃশ্যমান এলাকার কন্টেন্ট পার্স করুন
const observer = new IntersectionObserver((entries) => {
  entries.forEach(entry => {
    if (entry.isIntersecting) {
      parseAndRender(entry.target);
    }
  });
});

স্ট্রিমিং প্রসেসিং

javascript
// বড় ফাইলের জন্য স্ট্রিম পার্সিং
const fs = require('fs');
const { Transform } = require('stream');

const markdownTransform = new Transform({
  transform(chunk, encoding, callback) {
    const html = marked.parse(chunk.toString());
    callback(null, html);
  }
});

fs.createReadStream('large-document.md')
  .pipe(markdownTransform)
  .pipe(fs.createWriteStream('output.html'));

সাধারণ সমস্যা

১. লাইন ব্রেক সমস্যা

বিভিন্ন পার্সার লাইন ব্রেক বিভিন্নভাবে হ্যান্ডেল করতে পারে:

markdown
লাইন ১
লাইন ২        ← এগুলো একই অনুচ্ছেদ হিসেবে পার্স হতে পারে

লাইন ১  
লাইন ২        ← লাইনের শেষে দুটি স্পেস জোরপূর্বক লাইন ব্রেক দেয়

লাইন ১

লাইন ২        ← খালি লাইন অনুচ্ছেদ আলাদা করে

২. HTML মিশ্রণ

markdown
এটি **Markdown** এবং <em>HTML</em> এর মিশ্রণ।

HTML ট্যাগের সঠিক ক্লোজিং এবং নেস্টিংয়ের দিকে মনোযোগ দিন।

৩. বিশেষ ক্যারেক্টার এস্কেপিং

markdown
এখানে \* এবং \_ ক্যারেক্টার এস্কেপ করতে হবে।

বাস্তব প্রয়োগের পরিস্থিতি

১. ব্লগ সিস্টেম

Markdown নিবন্ধ → স্ট্যাটিক সাইট জেনারেটর → HTML ওয়েবসাইট

২. ডকুমেন্টেশন সাইট

.md ডকুমেন্ট → VitePress/Docusaurus → অনলাইন ডকুমেন্টেশন

৩. README ফাইল

README.md → GitHub/GitLab → প্রকল্প হোমপেজ

৪. নোট-টেকিং অ্যাপ

Markdown নোট → রিয়েল-টাইম রেন্ডারিং → রিচ টেক্সট ডিসপ্লে

পরবর্তী পদক্ষেপ

এখন যেহেতু আপনি Markdown কীভাবে কাজ করে তা বুঝতে পেরেছেন, আপনি যা করতে পারেন:

www.markdownlang.com দ্বারা নির্মিত