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

معرفی DOM

DOM (Document Object Model) یا مدل شیء سند، یک مفهوم کلیدی در JavaScript است که به توسعه‌دهندگان اجازه می‌دهد ساختار و محتوای یک صفحه وب را به‌طور برنامه‌نویسی دستکاری کنند. می‌توان یک صفحه وب را مانند یک خانه تصور کرد و DOM را به‌عنوان نقشه ساختمان آن دید. همان‌طور که نقشه خانه نشان می‌دهد اتاق‌ها، دیوارها و وسایل کجا قرار دارند، DOM محل عناصر صفحه مانند تیترها، پاراگراف‌ها، تصاویر و دکمه‌ها را نمایش می‌دهد. با استفاده از DOM می‌توان محتوای صفحه، سبک‌ها و ساختار را به‌صورت پویا تغییر داد بدون نیاز به بارگذاری مجدد کل صفحه.
DOM برای ایجاد صفحات وب تعاملی و پویا ضروری است. در یک فروشگاه آنلاین می‌توانید اطلاعات محصولات را به‌روز کنید؛ در سایت خبری تیترها را لحظه‌ای تغییر دهید؛ در وبلاگ شخصی پست‌ها یا نظرات را اضافه کنید؛ و در پرتال دولتی محتوا را به‌صورت پویا نمایش دهید.
در این آموزش، شما خواهید آموخت چگونه عناصر HTML را انتخاب کنید، محتوای آن‌ها را تغییر دهید، ویژگی‌ها (attributes) را مدیریت کنید و تعاملات کاربران را با رویدادها (events) کنترل کنید. یادگیری DOM مانند سازمان‌دهی یک کتابخانه است: شما می‌دانید هر کتاب کجاست و چگونه آن را پیدا یا جابجا کنید. در پایان این دوره می‌توانید صفحات وب تعاملی با تکنیک‌های پایه DOM بسازید.

مثال پایه

javascript
JAVASCRIPT Code
// دسترسی به یک عنصر و تغییر محتوای آن

<!DOCTYPE html>

<html>
<body>
<h1 id="title">خوش آمدید!</h1>
<script>
// گرفتن عنصر با استفاده از ID
let element = document.getElementById("title");
// تغییر محتوای متن عنصر
element.textContent = "خوش آمدید به فروشگاه آنلاین من!";
</script>
</body>
</html>

در این مثال پایه، یک صفحه HTML ساده با یک عنصر

و شناسه (ID) "title" داریم. با دستور document.getElementById("title") به این عنصر در DOM دسترسی پیدا می‌کنیم. getElementById یکی از رایج‌ترین روش‌ها برای انتخاب عنصر بر اساس شناسه یکتا است.
پس از دسترسی به عنصر، با استفاده از ویژگی textContent، متن داخل عنصر را تغییر می‌دهیم. این روش به ما امکان می‌دهد محتوای صفحه را بدون بارگذاری مجدد، به‌طور پویا به‌روزرسانی کنیم. هر عنصر در DOM به‌عنوان یک شیء در JavaScript نمایش داده می‌شود و می‌توانیم ویژگی‌ها و متدهای آن را تغییر دهیم. این شبیه سازمان‌دهی یک کتابخانه است: می‌دانید هر کتاب کجاست و می‌توانید آن را مطالعه، حذف یا جابجا کنید. در عمل، این تکنیک می‌تواند برای به‌روزرسانی محصولات در فروشگاه آنلاین، تغییر مقالات در وبلاگ یا اخبار و مدیریت محتوای پرتال‌های دولتی استفاده شود.

مثال کاربردی

javascript
JAVASCRIPT Code
// بروزرسانی پویا یک پست خبری

<!DOCTYPE html>

<html>
<body>
<h2 id="post-title">خبر امروز</h2>
<p id="post-content">محتوای اصلی خبر.</p>
<button id="update-btn">به‌روزرسانی خبر</button>
<script>
// دسترسی به عناصر
let postTitle = document.getElementById("post-title");
let postContent = document.getElementById("post-content");
let button = document.getElementById("update-btn");

// افزودن رویداد کلیک به دکمه
button.addEventListener("click", function() {
postTitle.textContent = "خبر فوری";
postContent.textContent = "این پست به‌صورت پویا از طریق DOM به‌روزرسانی شد!";
}); </script>

</body>
</html>

در این مثال کاربردی، یک پست خبری با دکمه‌ای برای بروزرسانی ایجاد کرده‌ایم. صفحه شامل یک عنوان، یک پاراگراف و یک دکمه است. با استفاده از getElementById، به عناصر دسترسی پیدا کرده و با addEventListener، رویداد "click" را به دکمه متصل می‌کنیم. هنگامی که کاربر روی دکمه کلیک می‌کند، عنوان و محتوا به‌صورت پویا تغییر می‌کند.
این روش شبیه تزئین یک اتاق یا جابجایی وسایل است: شما کل خانه را دوباره نمی‌سازید، بلکه عناصر موجود را تغییر می‌دهید. در سایت‌های خبری یا وبلاگ‌ها، محتوا به‌صورت بلادرنگ به‌روزرسانی می‌شود. در فروشگاه آنلاین، اطلاعات محصولات فوراً نمایش داده می‌شود و در پرتال‌های دولتی، تعاملات کاربر به‌طور پویا نشان داده می‌شود. برای مبتدیان مهم است که مطمئن شوند رویداد به عنصر صحیح متصل شده است تا بروزرسانی به درستی کار کند.

بهترین روش‌ها و اشتباهات رایج در کار با DOM:
بهترین روش‌ها:

  1. استفاده از انتخابگرهای مدرن مانند getElementById و querySelector برای خوانایی و نگهداری بهتر کد.
  2. استفاده از addEventListener برای افزودن رویدادها بدون بازنویسی رویدادهای موجود.
  3. ذخیره عناصر DOM در متغیرها به جای پرس‌وجوی مکرر برای بهبود عملکرد.
  4. قبل از تغییر یک عنصر، بررسی کنید که وجود دارد تا از خطاهای زمان اجرا جلوگیری شود.
    اشتباهات رایج:

  5. ایجاد عناصر یا رویدادها بدون پاک‌سازی، که باعث نشت حافظه می‌شود.

  6. دستکاری عناصر قبل از بارگذاری کامل DOM که به خطا منجر می‌شود.
  7. تغییرات مستقیم بیش از حد در DOM که عملکرد صفحه را کاهش می‌دهد.
  8. مدیریت نادرست خطا هنگام تغییر محتوا.
    نکات دیباگ: از console.log برای بررسی متغیرها و عناصر استفاده کنید و مطمئن شوید که رویداد DOMContentLoaded اجرا شده است. نگهداری کد سازمان‌یافته باعث سهولت در توسعه و نگهداری می‌شود.

📊 مرجع سریع

Property/Method Description Example
getElementById دسترسی به عنصر با ID یکتا document.getElementById("myId")
querySelector دسترسی به اولین عنصر مطابق با سلکتور document.querySelector(".class")
textContent خواندن یا تغییر محتوای متن element.textContent = "متن جدید"
addEventListener اتصال رویداد به عنصر element.addEventListener("click", function(){})
appendChild اضافه کردن یک عنصر فرزند به والد parent.appendChild(child)
removeChild حذف یک عنصر فرزند از والد parent.removeChild(child)

خلاصه و مراحل بعدی:
در این آموزش، با اصول پایه DOM شامل دسترسی به عناصر، تغییر متن و مدیریت رویدادها آشنا شدید. DOM برای ایجاد صفحات وب تعاملی ضروری است و پایه‌ای برای ارتباط با سرور و APIها فراهم می‌کند.
گام بعدی می‌تواند شامل ایجاد عناصر جدید با createElement، مدیریت جداول و لیست‌ها، هندل کردن رویدادهای پیچیده و ترکیب به‌روزرسانی DOM با AJAX برای بارگذاری محتوای پویا باشد. با پروژه‌های کوچک مانند وبلاگ یا فروشگاه آنلاین تمرین کنید. یادگیری DOM شبیه سازمان‌دهی یک کتابخانه یا اتاق است: شما می‌دانید هر چیز کجاست و چگونه بهینه مدیریت شود. تمرین مداوم شما را قادر می‌سازد صفحات وب تعاملی و کارآمد بسازید.

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

آماده شروع

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

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

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

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

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