🚀 ساخت یک TODO List ساده با Vanilla JavaScript (بدون فریمورک)
گاهی برای تمرین مفاهیم modern JS لازم نیست سراغ React یا Vue رفت؛ یک TODO List ساده با Vanilla JavaScript میتواند کلی چیز مثل DOM، event handling و localStorage را روشن کند 🤓
این ایده بر اساس مثالهای رسمی DOM و Storage در MDN است:
MDN querySelector
MDN localStorage
در این مینیپروژه:
✅ با querySelector و addEventListener کار میکنی
✅ آیتمها را در localStorage نگه میداری تا با رفرش صفحه نپرند
✅ یک ساختار کد تمیز و قابلگسترش میسازی
ایدهٔ سناریو 📝
فرض کن میخواهی کارهای روزانهات را روی مرورگر ثبت کنی؛ اضافهکردن task، حذفکردن، و اینکه با بستن تب همه چیز نپره. همین.
نمونه کد مینیمال (index.html + script.js در یک فولدر بگذار):
چند نکتهی کاربردی 💡
•
• همیشه قبل از push، مقدار input را
• با جداکردن تابعهای
این الگوی کوچک، بیس خیلی از appهای واقعی است: گرفتن input کاربر، update کردن state، sync با UI و نگهداشتن داده در storage. یک بار از اول تا آخر با حوصله بساز، بعدش هر فریمورکی را راحتتر میفهمی ✨
امتحانش روی یک فایل ساده HTML حس خوبی از «چیزی که خودم ساختم و کار میکند» میدهد؛ اگر دوست داشتی گسترشش بده و برای بقیهٔ devها بفرست 🌱
🔖 #Javascript #JS #جاوااسکریپت #JavaScript #DOM #localStorage #Vanilla_JS #Frontend
👤 Developix
💎 Channel: @DevelopixJavascript
گاهی برای تمرین مفاهیم modern JS لازم نیست سراغ React یا Vue رفت؛ یک TODO List ساده با Vanilla JavaScript میتواند کلی چیز مثل DOM، event handling و localStorage را روشن کند 🤓
این ایده بر اساس مثالهای رسمی DOM و Storage در MDN است:
MDN querySelector
MDN localStorage
در این مینیپروژه:
✅ با querySelector و addEventListener کار میکنی
✅ آیتمها را در localStorage نگه میداری تا با رفرش صفحه نپرند
✅ یک ساختار کد تمیز و قابلگسترش میسازی
ایدهٔ سناریو 📝
فرض کن میخواهی کارهای روزانهات را روی مرورگر ثبت کنی؛ اضافهکردن task، حذفکردن، و اینکه با بستن تب همه چیز نپره. همین.
نمونه کد مینیمال (index.html + script.js در یک فولدر بگذار):
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>Todo Vanilla JS</title>
<style>
body { font-family: sans-serif; max-width: 480px; margin: 40px auto; }
li { display: flex; justify-content: space-between; margin: 4px 0; }
button { margin-right: 8px; }
</style>
</head>
<body>
<h1>Todo List</h1>
<input id="todo-input" placeholder="New task..." />
<button id="add-btn">Add</button>
<ul id="todo-list"></ul>
<script>
const input = document.querySelector("#todo-input");
const addBtn = document.querySelector("#add-btn");
const list = document.querySelector("#todo-list");
let todos = JSON.parse(localStorage.getItem("todos") || "[]");
function save() {
localStorage.setItem("todos", JSON.stringify(todos));
}
function render() {
list.innerHTML = "";
todos.forEach((text, index) => {
const li = document.createElement("li");
li.textContent = text;
const removeBtn = document.createElement("button");
removeBtn.textContent = "x";
removeBtn.addEventListener("click", () => {
todos.splice(index, 1);
save();
render();
});
li.prepend(removeBtn);
list.appendChild(li);
});
}
addBtn.addEventListener("click", () => {
const value = input.value.trim();
if (!value) return;
todos.push(value);
input.value = "";
save();
render();
});
render();
</script>
</body>
</html>
چند نکتهی کاربردی 💡
•
JSON.parse و JSON.stringify اینجا برای تبدیل آرایه به string و برعکس استفاده شده؛ دقیقا مطابق چیزی که MDN برای localStorage پیشنهاد میدهد.• همیشه قبل از push، مقدار input را
.trim() کن تا task خالی ذخیره نشود.• با جداکردن تابعهای
save و render، بعدا راحت میشود featureهایی مثل edit یا checkbox برای completed اضافه کرد.این الگوی کوچک، بیس خیلی از appهای واقعی است: گرفتن input کاربر، update کردن state، sync با UI و نگهداشتن داده در storage. یک بار از اول تا آخر با حوصله بساز، بعدش هر فریمورکی را راحتتر میفهمی ✨
امتحانش روی یک فایل ساده HTML حس خوبی از «چیزی که خودم ساختم و کار میکند» میدهد؛ اگر دوست داشتی گسترشش بده و برای بقیهٔ devها بفرست 🌱
🔖 #Javascript #JS #جاوااسکریپت #JavaScript #DOM #localStorage #Vanilla_JS #Frontend
👤 Developix
💎 Channel: @DevelopixJavascript
🔥7❤3
✨ ساخت یک Todo List ساده با JavaScript خالص (بدون Framework)
خیلی وقتها برای تمرین JavaScript و DOM، یک پروژه کوچیک و واقعی مثل Todo List بهترین گزینهست. هم رویدادها رو لمس میکنی، هم کار با DOM و هم مدیریت state ساده رو.
یکی از بهترین رفرنسها برای کار با DOM و رویدادها، مستندات MDN هست:
MDN DOM Introduction
در این تمرین، با چند مفهوم مهم سر و کار داریم:
✅ گرفتن elementها با
✅ گوش دادن به eventها مثل
✅ جلوگیری از refresh فرم با
✅ دستکاری DOM با
مثال زیر یک Todo List خیلی ساده ولی عملی است. کافیست یک فایل
نکتههای ریز 👇
• استفاده از
• با
• با
این تمرین پایه خوبی برای قدمهای بعدی مثل ذخیرهسازی در
امتحانش روی یک فایل ساده لوکال حس خوبی از «کار کردن کد» میدهد و درک DOM را خیلی محکمتر میکند. اگر به درد دوستی میخورد که تازه JavaScript را شروع کرده، برایش بفرست 💚
🔖 #Javascript #JS #جاوااسکریپت #JavaScript #DOM #Todo #Frontend #ES6 #VanillaJS
👤 Developix
💎 Channel: @DevelopixJavascript
خیلی وقتها برای تمرین JavaScript و DOM، یک پروژه کوچیک و واقعی مثل Todo List بهترین گزینهست. هم رویدادها رو لمس میکنی، هم کار با DOM و هم مدیریت state ساده رو.
یکی از بهترین رفرنسها برای کار با DOM و رویدادها، مستندات MDN هست:
MDN DOM Introduction
در این تمرین، با چند مفهوم مهم سر و کار داریم:
✅ گرفتن elementها با
querySelector✅ گوش دادن به eventها مثل
submit و click✅ جلوگیری از refresh فرم با
event.preventDefault()✅ دستکاری DOM با
createElement و appendChildمثال زیر یک Todo List خیلی ساده ولی عملی است. کافیست یک فایل
index.html بسازی و این کد را داخلش قرار بدهی و در مرورگر باز کنی:<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8" />
<title>Simple Todo</title>
<style>
body { font-family: sans-serif; max-width: 480px; margin: 40px auto; }
form { display: flex; gap: 8px; }
ul { padding: 0; list-style: none; }
li { display: flex; justify-content: space-between; margin: 4px 0; }
button { cursor: pointer; }
</style>
</head>
<body>
<h1>Todo List</h1>
<form id="todo-form">
<input id="todo-input" placeholder="New task..." required />
<button type="submit">Add</button>
</form>
<ul id="todo-list"></ul>
<script>
const form = document.querySelector('#todo-form');
const input = document.querySelector('#todo-input');
const list = document.querySelector('#todo-list');
form.addEventListener('submit', function (event) {
event.preventDefault();
const text = input.value.trim();
if (!text) return;
const li = document.createElement('li');
const span = document.createElement('span');
span.textContent = text;
const removeBtn = document.createElement('button');
removeBtn.textContent = 'x';
removeBtn.addEventListener('click', function () {
list.removeChild(li);
});
li.appendChild(span);
li.appendChild(removeBtn);
list.appendChild(li);
input.value = '';
input.focus();
});
</script>
</body>
</html>
نکتههای ریز 👇
• استفاده از
trim() جلوی اضافه شدن تسک خالی را میگیرد.• با
event.preventDefault() فرم صفحه را reload نمیکند و کنترل دست ما میماند.• با
addEventListener روی خود دکمه حذف کار میکنیم تا ساختار کد تمیزتر بماند.این تمرین پایه خوبی برای قدمهای بعدی مثل ذخیرهسازی در
localStorage، اضافه کردن فیلتر (Completed / Active) یا بعداً پیادهسازی همین ایده در React یا Vue است.امتحانش روی یک فایل ساده لوکال حس خوبی از «کار کردن کد» میدهد و درک DOM را خیلی محکمتر میکند. اگر به درد دوستی میخورد که تازه JavaScript را شروع کرده، برایش بفرست 💚
🔖 #Javascript #JS #جاوااسکریپت #JavaScript #DOM #Todo #Frontend #ES6 #VanillaJS
👤 Developix
💎 Channel: @DevelopixJavascript
🔥6