در حال بارگذاری...

عنصر Template در HTML

عنصر <template> در HTML یک ابزار پیشرفته و کاربردی برای توسعه‌دهندگان وب است که به آن‌ها اجازه می‌دهد قطعاتی از کد HTML را به‌صورت مخفی (invisible) در صفحه نگهداری کنند تا در زمان مناسب، توسط JavaScript در DOM درج (insert) شود. این عنصر مانند آماده‌سازی طرح یک اتاق پیش از دکوراسیون آن است — محتوا آماده می‌شود اما تا زمانی که لازم نباشد، به کاربران نمایش داده نمی‌شود.
فرض کنید شما در حال طراحی یک پرتال دولتی هستید که باید بارها یک کارت اطلاعاتی را برای شهروندان مختلف نمایش دهد، یا در یک فروشگاه آنلاین باید محصولات را با فرمت یکسان اما با محتوای متفاوت نمایش دهید. با استفاده از <template>، می‌توانید یک ساختار تکراری را یک‌بار تعریف کرده و در صورت نیاز، با محتوای متفاوت در صفحه قرار دهید.
در این آموزش، شما با مفهوم دقیق و پیشرفته‌ی عنصر Template در HTML، کاربردهای آن در پروژه‌های واقعی مانند فروشگاه آنلاین، وب‌سایت خبری، وبلاگ شخصی و پرتال دولتی، و بهترین شیوه‌های استفاده از آن آشنا خواهید شد. همچنین یاد خواهید گرفت چگونه با کمک جاوااسکریپت، این قالب‌ها را به‌طور پویا به DOM اضافه کنید.

مثال پایه

html
HTML Code
<!-- تعریف یک قالب کارت کاربر -->
<template id="user-card-template">
<div class="user-card">
<h3 class="name">نام کاربر</h3>
<p class="info">اطلاعات کاربر</p>
</div>
</template>

در کد بالا، ما یک عنصر <template> با شناسه user-card-template تعریف کرده‌ایم. داخل این عنصر، ساختار یک کارت کاربر قرار دارد که شامل یک عنوان <h3> و یک پاراگراف اطلاعاتی <p> است. نکته‌ی مهم این است که محتوای داخل <template> هنگام بارگذاری صفحه به‌صورت مستقیم در DOM نمایش داده نمی‌شود. درواقع، این کد در حافظه ذخیره شده و تنها زمانی نمایش داده می‌شود که با استفاده از JavaScript آن را به DOM اضافه کنیم.
بخش‌های اصلی کد:

  • <template>: عنصر ویژه‌ای است که محتوای درونش هنگام بارگذاری صفحه فعال نیست.
  • id="user-card-template": شناسه‌ای برای دسترسی به قالب از طریق JavaScript.
  • <div class="user-card">: ساختار کارت که می‌تواند برای کاربران مختلف تکرار شود.
  • <h3 class="name"> و <p class="info">: محتوای پویا که بعداً از طریق جاوااسکریپت مقداردهی می‌شود.
    برای مبتدیان، ممکن است سوال ایجاد شود که چرا این قالب در مرورگر نمایش داده نمی‌شود؟ پاسخ این است که مرورگر به‌طور پیش‌فرض محتوای داخل <template> را رندر نمی‌کند و باید با جاوااسکریپت فعال شود.
    از نظر کاربردی، این ساختار برای تولید کارت محصولات، مطالب خبری، یا معرفی نویسندگان در وبلاگ بسیار مناسب است، چون کدهای HTML تکراری را کاهش می‌دهد و باعث عملکرد بهتر و کدی مرتب‌تر می‌شود.

مثال کاربردی

html
HTML Code
<template id="product-template">
<div class="product-card">
<h4 class="title"></h4>
<p class="price"></p>
</div>
</template>

<section id="product-list"></section>

<script>
const products = [
{ title: "کفش ورزشی", price: "۵۰۰٬۰۰۰ تومان" },
{ title: "کوله‌پشتی مسافرتی", price: "۸۲۰٬۰۰۰ تومان" }
];

const template = document.getElementById("product-template");
const container = document.getElementById("product-list");

products.forEach(product => {
const clone = template.content.cloneNode(true);
clone.querySelector(".title").textContent = product.title;
clone.querySelector(".price").textContent = product.price;
container.appendChild(clone);
});
</script>

بهترین شیوه‌ها و خطاهای رایج
شیوه‌های پیشنهادی:

  1. استفاده از HTML معنایی (Semantic HTML): درون قالب‌ها از عناصری مانند <article>، <section> یا <header> استفاده کنید تا ساختار قابل درک‌تر و استاندارد باشد.
  2. تمیزی ساختار کد (Clean Markup): درون قالب فقط ساختار HTML قرار دهید؛ از قرار دادن CSS و اسکریپت‌های غیرضروری خودداری کنید.
  3. پرهیز از شناسه‌های تکراری: هنگام کلون‌ کردن (clone) محتوا، از داشتن ID تکراری پرهیز کنید.
  4. استفاده محدود از قالب‌ها: فقط زمانی قالب را به صفحه اضافه کنید که لازم است، تا سرعت بارگذاری بهینه باقی بماند.
    خطاهای رایج:

  5. استفاده نادرست از .content: دسترسی به محتوای قالب فقط از طریق template.content ممکن است.

  6. انتظار برای نمایش خودکار: محتویات قالب تا زمانی که با JavaScript به DOM اضافه نشوند، نمایش داده نمی‌شوند.
  7. ساختار نادرست عناصر: تودرتویی نادرست (مثل قرار دادن تگ <script> داخل قالب) باعث بروز مشکلات می‌شود.
  8. استفاده از CSS داخلی درون قالب: استفاده از استایل‌های inline باعث می‌شود قالب سخت‌تر قابل نگهداری باشد.
    نکات رفع اشکال (Debugging):
  • با استفاده از console.log(template.content) بررسی کنید آیا محتوا قابل دسترسی است.
  • از ابزار Inspect مرورگر برای مشاهده DOM استفاده کنید.
  • از cloneNode(true) مطمئن شوید که تمام ساختار به‌طور کامل کپی می‌شود.
    توصیه نهایی:
    همواره قالب‌ها را با کامنت مشخص کنید، و هنگام افزودن به DOM به درستی مدیریت محتوا انجام دهید تا از تکرار، خطا و بار اضافه جلوگیری شود.

📊 مرجع سریع

Property/Method Description Example
template.content دسترسی به محتوای قالب به‌صورت DocumentFragment template.content.cloneNode(true)
cloneNode(true) کپی کامل ساختار داخلی قالب const clone = template.content.cloneNode(true)
querySelector() یافتن عناصر داخل قالب کلون‌شده clone.querySelector(".title")
appendChild() اضافه کردن قالب به DOM container.appendChild(clone)
id شناسه‌ی قالب برای انتخاب با JavaScript document.getElementById("product-template")
DocumentFragment واحد موقت برای عملکرد بهتر در DOM let frag = template.content

جمع‌بندی و گام‌های بعدی
در این آموزش با عنصر <template> در HTML به‌صورت کامل و پیشرفته آشنا شدید. این عنصر یکی از ابزارهای کلیدی برای ساخت رابط‌های کاربری پویا و بهینه است. کاربرد آن در وب‌سایت‌هایی با محتوای تکراری مانند فروشگاه‌ها، وب‌سایت‌های خبری، بلاگ‌ها و پرتال‌های دولتی به‌شدت مفید است.
نکات کلیدی:

  • قالب‌ها هنگام بارگذاری صفحه نمایش داده نمی‌شوند.
  • فقط با JavaScript و از طریق cloneNode() به DOM افزوده می‌شوند.
  • باعث بهبود ساختار، خوانایی و کارایی پروژه می‌شوند.
    ارتباط با CSS و JavaScript:
    قالب‌ها پس از وارد شدن به DOM می‌توانند با CSS استایل‌دهی شوند. همچنین با کمک JavaScript، محتواهای پویا و متنوع درون آن‌ها قرار می‌گیرد که امکان تعامل با کاربر را افزایش می‌دهد.
    موضوعات پیشنهادی برای یادگیری بعدی:

  • Web Components و Shadow DOM

  • استفاده از فریم‌ورک‌هایی مانند Vue یا Lit برای Templating
  • بهینه‌سازی DOM و مدیریت حافظه
    توصیه‌های عملی:
    در پروژه‌های بعدی خود، برای عناصر تکرارشونده از قالب‌ها استفاده کنید. کد شما ساختار یافته‌تر، نگهداری آسان‌تر، و کارایی آن بیشتر خواهد شد.

🧠 دانش خود را بیازمایید

آماده شروع

آزمون دانش شما

درک خود از این موضوع را با سوالات کاربردی بسنجید.

4
سوالات
🎯
70%
برای قبولی
♾️
زمان
🔄
تلاش‌ها

📝 دستورالعمل‌ها

  • هر سوال را با دقت بخوانید
  • بهترین پاسخ را برای هر سوال انتخاب کنید
  • می‌توانید آزمون را هر چند بار که می‌خواهید تکرار کنید
  • پیشرفت شما در بالا نمایش داده می‌شود