آموزش ساخت یک Todo List با استفاده از DOM و جاوا اسکریپت: راهنمای گام به گام

دسته : آموزش رایگان جاوا اسکریپت (JavaScript)

آموزش ساخت یک Todo List با استفاده از DOM و جاوا اسکریپت: راهنمای گام به گام

آموزش ساخت یک Todo List با استفاده از DOM و جاوا اسکریپت: راهنمای گام به گام

ساخت یک Todo List با استفاده از جاوااسکریپت و DOM یکی از پروژه‌های محبوب و کاربردی برای یادگیری نحوه مدیریت المان‌های HTML و ایجاد تعاملات پویا در صفحات وب است. در این مقاله به صورت گام به گام نحوه ایجاد یک Todo List ساده را بررسی خواهیم کرد و نکات بهینه‌سازی و سئو مرتبط با استانداردهای گوگل را نیز توضیح می‌دهیم.


اهداف این مقاله:

  • ایجاد المان‌های HTML به صورت داینامیک با استفاده از DOM

  • افزودن و حذف وظایف (Tasks) به لیست

  • مدیریت رویدادها و تعاملات کاربری

  • نکات بهینه‌سازی برای بهبود سئو و عملکرد


گام اول: ساختار HTML اولیه

در ابتدا یک فایل HTML ساده ایجاد می‌کنیم که شامل بخش‌هایی برای نمایش لیست وظایف، ورودی برای افزودن وظایف جدید، و یک دکمه برای اضافه کردن وظایف است.



< ! DOCTYPE html >
< html lang="fa" >
< head >
    < meta charset="UTF-8" >
    < meta name="viewport" content="width=device-width, initial-scale=1.0" >
    < title > Todo List < / title >
    < style >
        body {
            font-family: Arial, sans-serif;
            background-color: #f4f4f4;
            margin: 0;
            padding: 20px;
        }
        #todo-form {
            display: flex;
            justify-content: space-between;
        }
        #todo-input {
            width: 70%;
            padding: 10px;
            font-size: 16px;
        }
        #add-button {
            padding: 10px 20px;
            background-color: #28a745;
            color: white;
            border: none;
            cursor: pointer;
        }
        #add-button:hover {
            background-color: #218838;
        }
        #todo-list {
            list-style-type: none;
            padding: 0;
        }
        .todo-item {
            display: flex;
            justify-content: space-between;
            background-color: white;
            padding: 10px;
            margin-top: 10px;
            border: 1px solid #ddd;
            border-radius: 5px;
        }
        .delete-button {
            background-color: #dc3545;
            color: white;
            border: none;
            padding: 5px 10px;
            cursor: pointer;
        }
        .delete-button:hover {
            background-color: #c82333;
        }
    < / style >
< / head >
< body >
    < h1 > لیست کارهای روزانه < / h1 >
    < div id="todo-form" >
        < input type="text" id="todo-input" placeholder="کار جدید..." >
        < button id="add-button" > افزودن < / button >
    < / div >
    < ul id="todo-list" > < / ul >

    < script src="app.js" > < / script >
< / body >
< / html >


توضیحات HTML:

  • یک ورودی متنی برای وارد کردن کار جدید (todo-input).

  • یک دکمه برای افزودن کار جدید به لیست (add-button).

  • یک لیست نامرتب (ul) که وظایف جدید به آن اضافه خواهند شد (todo-list).


گام دوم: نوشتن کد جاوااسکریپت برای افزودن وظایف

حالا نوبت به نوشتن کد جاوااسکریپت می‌رسد. ابتدا باید کدی بنویسیم که وقتی کاربر روی دکمه "افزودن" کلیک می‌کند، کار جدید به لیست اضافه شود.

در فایل app.js، کد زیر را اضافه کنید:



// دسترسی به المان‌های صفحه
const todoInput = document.getElementById('todo-input');
const addButton = document.getElementById('add-button');
const todoList = document.getElementById('todo-list');

// افزودن وظیفه جدید
addButton.addEventListener('click', function() {
    const taskText = todoInput.value.trim();

    if (taskText === '') {
        alert('لطفاً یک کار وارد کنید');
        return;
    }

    // ایجاد المان‌های مربوط به وظیفه جدید
    const todoItem = document.createElement('li');
    todoItem.classList.add('todo-item');

    const taskContent = document.createElement('span');
    taskContent.textContent = taskText;

    const deleteButton = document.createElement('button');
    deleteButton.textContent = 'حذف';
    deleteButton.classList.add('delete-button');

    // اضافه کردن المان‌ها به لیست
    todoItem.appendChild(taskContent);
    todoItem.appendChild(deleteButton);
    todoList.appendChild(todoItem);

    // پاک کردن ورودی پس از افزودن
    todoInput.value = '';

    // اضافه کردن رویداد حذف به دکمه حذف
    deleteButton.addEventListener('click', function() {
        todoItem.remove();
    });
});


توضیحات کد:

  • ابتدا به المان‌های HTML مثل ورودی (todo-input)، دکمه (add-button) و لیست (todo-list) دسترسی پیدا می‌کنیم.

  • با کلیک بر روی دکمه افزودن، محتویات ورودی خوانده شده و بررسی می‌شود که آیا خالی است یا خیر. اگر خالی باشد، یک پیام هشدار نمایش داده می‌شود.

  • یک عنصر < li > جدید ایجاد می‌شود که شامل متن وظیفه و یک دکمه حذف است.

  • وظیفه به لیست اضافه می‌شود و رویداد کلیک برای دکمه حذف تعریف می‌شود تا وظیفه از لیست حذف شود.


گام سوم: افزودن قابلیت حذف وظایف

در مرحله قبل، قابلیت حذف وظایف را به صورت داینامیک اضافه کردیم. با کلیک بر روی دکمه "حذف" در کنار هر وظیفه، آن وظیفه از لیست حذف خواهد شد.


بهینه‌سازی و نکات سئو

  • استفاده از Lazy Loading: در صورتی که تعداد وظایف بسیار زیاد شود، می‌توانید از تکنیک بارگذاری تنبل (Lazy Loading) برای بارگذاری بخش‌های دیگر صفحه به صورت تدریجی استفاده کنید تا تجربه کاربری بهتری فراهم شود.

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

  • کاهش دستکاری‌های غیرضروری DOM: هرچه تغییرات و دستکاری‌های کمتری روی DOM اعمال کنید، سرعت صفحه بهتر می‌شود. اضافه و حذف المان‌ها باید بهینه باشد.

  • استفاده از Event Delegation: اگر تعداد زیادی وظیفه داشته باشید، به جای افزودن Event Listener برای هر دکمه حذف، می‌توانید از Event Delegation استفاده کنید تا به جای هر وظیفه، تنها یک Event Listener به والد اعمال شود. این تکنیک باعث بهبود عملکرد می‌شود.


بهینه‌سازی حذف با Event Delegation:



todoList.addEventListener('click', function(event) {
    if (event.target.classList.contains('delete-button')) {
        event.target.parentElement.remove();
    }
});


در این روش، رویداد کلیک تنها به عنصر والد (todoList) اضافه شده و سپس بررسی می‌شود که آیا عنصر کلیک شده دکمه حذف است یا خیر. اگر بله، آن وظیفه حذف می‌شود. این کار باعث کاهش تعداد Event Listenerها و بهبود عملکرد صفحه می‌شود.


نتیجه‌گیری

ساخت یک Todo List ساده با استفاده از جاوااسکریپت و DOM به شما این امکان را می‌دهد تا با مفاهیم اساسی جاوااسکریپت مانند دستکاری DOM، مدیریت رویدادها و تعاملات کاربری آشنا شوید. با رعایت نکات بهینه‌سازی عملکرد و سئو، می‌توانید صفحات وب تعاملی، سریع و بهینه برای کاربران و موتورهای جستجو بسازید. گوگل سایت‌هایی که سریع‌تر بارگذاری می‌شوند و تجربه کاربری بهتری دارند، رتبه بهتری می‌دهد، بنابراین بهینه‌سازی‌های انجام‌شده نه‌تنها به بهبود تجربه کاربری کمک می‌کند، بلکه سئوی سایت شما را نیز بهبود خواهد داد.

پرسش و پاسخ

نظری یافت نشد

مطالب مشابه

آموزش انیمیشن‌های پیشرفته با keyframes در CSS: طراحی حرکات پویا و چند مرحله‌ای

آموزش انیمیشن‌های پیشرفته با keyframes در CSS: طراحی حرکات پویا و چند مرحله‌ای

18م شهریور 1402

مطالعه بیشتر

آموزش ترانزیشن‌ها و انیمیشن‌های نرم با CSS: ایجاد افکت‌های پویا و واکنش‌گرا

آموزش ترانزیشن‌ها و انیمیشن‌های نرم با CSS: ایجاد افکت‌های پویا و واکنش‌گرا

10م شهریور 1402

مطالعه بیشتر

آموزش مفاهیم پایه‌ای اشیاء در جاوا اسکریپت: تعریف، ویژگی‌ها و متدها

آموزش مفاهیم پایه‌ای اشیاء در جاوا اسکریپت: تعریف، ویژگی‌ها و متدها

2م شهریور 1403

مطالعه بیشتر

مدیریت خطاها در Async/Await و Promises در جاوا اسکریپت: راهنمای کامل با مثال‌های عملی

مدیریت خطاها در Async/Await و Promises در جاوا اسکریپت: راهنمای کامل با مثال‌های عملی

30م مهر 1403

مطالعه بیشتر

استفاده از overflow در CSS برای مدیریت محتوای اضافی: راهنمای کامل و کاربردی

استفاده از overflow در CSS برای مدیریت محتوای اضافی: راهنمای کامل و کاربردی

11م آبان 1403

مطالعه بیشتر

آموزش جامع توابع در جاوا اسکریپت: نحوه تعریف، فراخوانی و بازگشت مقادیر

آموزش جامع توابع در جاوا اسکریپت: نحوه تعریف، فراخوانی و بازگشت مقادیر

2م بهمن 1402

مطالعه بیشتر

استفاده از setTimeout و setInterval در جاوا اسکریپت: آموزش کامل و مثال‌ها

استفاده از setTimeout و setInterval در جاوا اسکریپت: آموزش کامل و مثال‌ها

29م مهر 1403

مطالعه بیشتر

آشنایی با Inheritance در CSS: اصول وراثت و مدیریت استایل‌ها

آشنایی با Inheritance در CSS: اصول وراثت و مدیریت استایل‌ها

12م آبان 1403

مطالعه بیشتر

آموزش اصول Web APIs و نحوه استفاده از آن‌ها در جاوا اسکریپت: راهنمای کامل با مثال‌ها

آموزش اصول Web APIs و نحوه استفاده از آن‌ها در جاوا اسکریپت: راهنمای کامل با مثال‌ها

1م آبان 1403

مطالعه بیشتر

آموزش ایجاد تصویر و لینک در HTML: نحوه استفاده از تگ‌های img و a

آموزش ایجاد تصویر و لینک در HTML: نحوه استفاده از تگ‌های img و a

21م مرداد 1402

مطالعه بیشتر

آموزش تغییر نوع و اندازه فونت و رنگ متن با CSS: استایل‌دهی حرفه‌ای به متن‌ها

آموزش تغییر نوع و اندازه فونت و رنگ متن با CSS: استایل‌دهی حرفه‌ای به متن‌ها

5م شهریور 1402

مطالعه بیشتر

آموزش استفاده از cubic-bezier در CSS برای انیمیشن‌های سفارشی و حرفه‌ای

آموزش استفاده از cubic-bezier در CSS برای انیمیشن‌های سفارشی و حرفه‌ای

12م آبان 1403

مطالعه بیشتر

تمامی حقوق معتلق به ناشر سایت است و کپی از آن پیگرد قانونی دارد