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

تایمرها و زمان‌بندی

در جاوااسکریپت، «تایمرها و زمان‌بندی» (Timers and Scheduling) یکی از ابزارهای کلیدی برای کنترل جریان اجرای کد محسوب می‌شوند. تایمرها این امکان را فراهم می‌کنند که اجرای یک قطعه کد را به آینده موکول کنیم یا آن را در بازه‌های زمانی مشخص تکرار کنیم. اهمیت این قابلیت زمانی روشن می‌شود که بخواهیم تعاملات پویا و زمان‌بندی‌شده در وب‌سایت‌ها و برنامه‌های کاربردی داشته باشیم.
به‌عنوان مثال، در یک فروشگاه آنلاین (online shop) می‌توان از تایمرها برای ایجاد شمارش معکوس پیشنهادهای ویژه استفاده کرد. در یک وب‌سایت خبری (news website)، نمایش خودکار آخرین خبرها یا به‌روزرسانی تیترها نیازمند زمان‌بندی دقیق است. در وبلاگ شخصی (personal blog)، می‌توان برای نمایش اسلایدشو تصاویر تایمرها را به کار برد. حتی در پرتال‌های دولتی (government portal)، زمان‌بندی نقش مهمی در به‌روزرسانی خودکار داده‌ها و اطلاعیه‌ها ایفا می‌کند.
این آموزش به شما نشان خواهد داد که چگونه از توابعی مثل setTimeout و setInterval برای اجرای وظایف زمان‌بندی‌شده استفاده کنید، چه خطاهایی رایج است و چگونه از بهترین روش‌ها برای بهینه‌سازی عملکرد بهره ببرید. اگر این موضوع را به استعاره تشبیه کنیم، تایمرها همانند «ساعت دیواری» در یک خانه هستند: همان‌طور که ساعت وظایف روزمره ما را تنظیم می‌کند، تایمرها نیز کارکردهای یک وب‌اپلیکیشن را در لحظه‌های مناسب هماهنگ می‌سازند.

مثال پایه

javascript
JAVASCRIPT Code
// اجرای یک پیام بعد از 3 ثانیه
setTimeout(() => {
console.log("سلام! این پیام با تاخیر نمایش داده شد.");
}, 3000); // 3000 میلی‌ثانیه = 3 ثانیه

در این کد ساده اما قدرتمند، از تابع setTimeout استفاده شده است. تابع setTimeout یکی از رایج‌ترین ابزارها برای زمان‌بندی در جاوااسکریپت است. این تابع دو آرگومان دریافت می‌کند: اول، یک تابع (function) که باید اجرا شود، و دوم، میزان تاخیر بر حسب میلی‌ثانیه (milliseconds).
در مثال بالا، ما یک تابع فلشی (arrow function) تعریف کرده‌ایم:
() => { console.log("سلام! ..."); }
این تابع تنها وظیفه‌اش نمایش یک پیام در کنسول است. سپس این تابع به setTimeout داده می‌شود. آرگومان دوم یعنی 3000 مشخص می‌کند که اجرای این تابع بعد از سه ثانیه انجام شود.
برای درک بهتر، تصور کنید در یک وب‌سایت خبری قصد دارید بعد از بارگذاری صفحه، یک اعلان خوش‌آمدگویی یا یک خبر فوری نمایش داده شود. استفاده از setTimeout این امکان را فراهم می‌کند. همین تکنیک در فروشگاه‌های آنلاین برای نمایش پیام‌های تبلیغاتی یا در وبلاگ‌ها برای نمایش اسلایدها بسیار مفید است.
یکی از سوالات متداول این است که آیا کد دیگر در طول این سه ثانیه متوقف می‌شود؟ پاسخ منفی است. جاوااسکریپت غیرهمزمان (asynchronous) عمل می‌کند، بنابراین اجرای بقیه کدها ادامه می‌یابد و فقط اجرای این تابع به آینده موکول می‌شود. این همان نکته کلیدی تایمرهاست که اجازه می‌دهد چندین فرآیند همزمان مدیریت شوند.

مثال کاربردی

javascript
JAVASCRIPT Code
// ایجاد شمارش معکوس در یک فروشگاه آنلاین
let timeLeft = 5;
const timer = setInterval(() => {
console.log(`زمان باقی‌مانده: ${timeLeft} ثانیه`);
timeLeft--;
if (timeLeft < 0) {
clearInterval(timer); // توقف تایمر
console.log("پیشنهاد ویژه به پایان رسید!");
}
}, 1000); // هر 1 ثانیه یکبار اجرا شود

در این مثال عملی، از تابع setInterval استفاده کرده‌ایم. setInterval مشابه setTimeout است با این تفاوت که به‌صورت تکرارشونده عمل می‌کند. یعنی تابع مشخص‌شده را در بازه‌های زمانی ثابت اجرا می‌کند تا زمانی که با clearInterval متوقف شود.
در اینجا یک شمارش معکوس برای پیشنهاد ویژه در فروشگاه آنلاین ایجاد کرده‌ایم. متغیر timeLeft مقدار 5 دارد که نشان‌دهنده 5 ثانیه باقی‌مانده است. تابع setInterval هر 1000 میلی‌ثانیه (1 ثانیه) اجرا می‌شود. در هر بار اجرا، مقدار timeLeft چاپ می‌شود و سپس یک واحد کاهش می‌یابد. وقتی timeLeft کمتر از صفر شد، clearInterval فراخوانی می‌شود تا تایمر متوقف گردد و پیامی مبنی بر پایان پیشنهاد ویژه نمایش داده شود.
این ساختار را می‌توان به‌طور مستقیم در سایت‌های خبری برای شمارش معکوس انتشار اخبار فوری، در وبلاگ‌ها برای کنترل اسلایدشو یا حتی در پرتال‌های دولتی برای شمارش معکوس مهلت ثبت‌نام استفاده کرد.
Best practices و Common mistakes در این زمینه بسیار مهم هستند. اگر clearInterval فراموش شود، تایمر همچنان اجرا خواهد شد و می‌تواند منجر به هدررفت منابع (memory leak) شود. همچنین، در پروژه‌های واقعی بهتر است از متغیرهای معنادار استفاده کنیم و پیام‌ها را به زبان کاربر شخصی‌سازی کنیم.

بهترین روش‌ها (Best Practices) و اشتباهات رایج (Common Mistakes) در استفاده از تایمرها و زمان‌بندی:

  1. استفاده از سینتکس مدرن: همواره از توابع فلشی و const/let به جای var استفاده کنید تا کد شما خواناتر و ایمن‌تر باشد.
  2. مدیریت خطا (Error Handling): اگر تایمر به داده‌های خارجی وابسته است (مثلاً درخواست به سرور)، باید خطاها را مدیریت کنید تا برنامه متوقف نشود.
  3. بهینه‌سازی عملکرد (Performance Optimization): تایمرها را تنها زمانی فعال کنید که واقعاً نیاز دارید. تایمرهای غیرضروری مصرف CPU و حافظه را افزایش می‌دهند.
  4. توقف به‌موقع (Proper Clearing): همیشه تایمرها را با clearTimeout یا clearInterval در زمان مناسب متوقف کنید.
    اشتباهات رایج:

  5. فراموش کردن clearInterval یا clearTimeout که باعث مصرف بیهوده منابع می‌شود.

  6. اجرای همزمان چند تایمر بدون هماهنگی، که می‌تواند باعث تداخل در عملکرد شود.
  7. وابستگی بیش‌ازحد به تایمرها برای به‌روزرسانی UI به جای استفاده از event-driven programming.
  8. مدیریت نادرست خطاها که باعث می‌شود پیام‌های خطا در لاگ‌ها پنهان بمانند.
    برای Debugging توصیه می‌شود از console.log در مراحل اولیه استفاده کنید تا بدانید تایمر چه زمانی فعال و چه زمانی متوقف می‌شود. در پروژه‌های بزرگ‌تر، ابزارهای DevTools مرورگر کمک زیادی به ردیابی تایمرها می‌کنند.

📊 مرجع سریع

Property/Method Description Example
setTimeout اجرای یک تابع بعد از یک تاخیر مشخص setTimeout(fn, 2000)
clearTimeout توقف اجرای setTimeout clearTimeout(id)
setInterval اجرای تکراری یک تابع در بازه‌های مشخص setInterval(fn, 1000)
clearInterval توقف اجرای setInterval clearInterval(id)
Date.now دریافت زمان فعلی به میلی‌ثانیه برای زمان‌بندی دستی let t = Date.now()
requestAnimationFrame بهینه‌سازی انیمیشن با زمان‌بندی فریم‌ها requestAnimationFrame(draw)

خلاصه و گام‌های بعدی:
در این آموزش یاد گرفتید که تایمرها و زمان‌بندی (Timers and Scheduling) یکی از مهم‌ترین ابزارهای جاوااسکریپت برای ایجاد تعاملات پویا هستند. با setTimeout می‌توان وظایف را به آینده موکول کرد و با setInterval اجرای مکرر کارها را زمان‌بندی نمود. همچنین با clearTimeout و clearInterval توانستید یاد بگیرید که چگونه اجرای این تایمرها را در زمان مناسب متوقف کنید.
این مفاهیم مستقیماً به کار با HTML DOM نیز مرتبط هستند. برای مثال، می‌توانید با استفاده از تایمرها عناصر صفحه را در زمان مشخص تغییر دهید یا داده‌های سرور را با AJAX یا Fetch به‌صورت زمان‌بندی‌شده دریافت کنید. در بخش‌های پیشرفته‌تر، یادگیری promiseها و async/await در کنار تایمرها به شما کمک می‌کند تا کنترل بهتری بر جریان کد داشته باشید.
به‌عنوان گام‌های بعدی، پیشنهاد می‌شود مباحثی مثل Event Loop، Task Queue و Microtasks را بررسی کنید تا درک عمیق‌تری از نحوه زمان‌بندی در جاوااسکریپت داشته باشید. همچنین، یادگیری requestAnimationFrame برای بهینه‌سازی انیمیشن‌ها یک مسیر عالی برای توسعه بیشتر مهارت‌های شماست.

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

آماده شروع

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

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

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

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

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