### بررسی متد
متد
اما این متد یک پارامتر دوم هم دارد که معمولاً نادیده گرفته میشود! 😔
---
### ☺️ نگاهی به سینتکس پایه:
در این حالت:
* ✔️ اگر کلاس مورد نظر وجود داشته باشد، حذف میشود؛
* ✔️ اگر وجود نداشته باشد، افزوده میشود.
---
### ☺️ اما پارامتر
پارامتر
* ✔️
* ✔️
---
### 🔍 چند مثال:
---
### 🔧 این قابلیت کجا به کار میآید؟
برای همگامسازی وضعیت عناصر با منطق برنامه.
بهجای نوشتن شرطهای جداگانه برای بررسی وجود یا نبود کلاس، میتوان بهسادگی از یک شرط منطقی استفاده کرد:
---
### 📌 موارد کاربرد رایج:
* 🔵 فعالسازی تم تیره
* 🔵 باز یا بسته بودن منوها
* 🔵 مشخص کردن عنصر فعال
* 🔵 اعمال فیلتر یا مرتبسازی
---
### چرا مهم است؟
اگر از پارامتر
---
### ✅ نتیجهگیری:
استفاده از
* کاهش منطق اضافی (نیازی به شرطهای جداگانه نیست)
* کاهش حجم کد (فقط یک خط کد بهجای چندین خط شرطی)
* کاهش خطا (جلوگیری از ناهماهنگی بین وضعیت UI و دادهها)
در مجموع، روشی ساده و مؤثر برای همگامسازی دقیق وضعیت عناصر با منطق برنامه است. 👍
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
classList.toggle
همراه با پارامتر دوم 🤨متد
toggle
یکی از پرکاربردترین ابزارها برای مدیریت کلاسهای CSS در JavaScript است. این متد امکان تغییر پویا در وضعیت عناصر صفحه را با افزودن یا حذف کلاسها فراهم میکند.اما این متد یک پارامتر دوم هم دارد که معمولاً نادیده گرفته میشود! 😔
---
### ☺️ نگاهی به سینتکس پایه:
element.classList.toggle('className');
در این حالت:
* ✔️ اگر کلاس مورد نظر وجود داشته باشد، حذف میشود؛
* ✔️ اگر وجود نداشته باشد، افزوده میشود.
---
### ☺️ اما پارامتر
force
چیست؟element.classList.toggle('className', force);
پارامتر
force
یک مقدار بولی (true یا false) است که به طور صریح کنترل میکند که کلاس افزوده شود یا حذف:* ✔️
true
→ همیشه کلاس را افزوده خواهد کرد؛* ✔️
false
→ همیشه کلاس را حذف خواهد کرد.---
### 🔍 چند مثال:
menu.classList.toggle('open', true); // کلاس 'open' حتماً افزوده میشود
menu.classList.toggle('open', false); // کلاس 'open' حتماً حذف میشود
---
### 🔧 این قابلیت کجا به کار میآید؟
برای همگامسازی وضعیت عناصر با منطق برنامه.
بهجای نوشتن شرطهای جداگانه برای بررسی وجود یا نبود کلاس، میتوان بهسادگی از یک شرط منطقی استفاده کرد:
const isDarkMode = userSettings.theme === 'dark';
document.body.classList.toggle('dark-mode', isDarkMode);
---
### 📌 موارد کاربرد رایج:
* 🔵 فعالسازی تم تیره
* 🔵 باز یا بسته بودن منوها
* 🔵 مشخص کردن عنصر فعال
* 🔵 اعمال فیلتر یا مرتبسازی
---
### چرا مهم است؟
اگر از پارامتر
force
استفاده نشود، متد toggle
فقط وضعیت کلاس را بین حالت موجود و ناموجود جابهجا میکند. اما در دنیای واقعی توسعه، معمولاً نیاز به کنترل دقیق و هماهنگ با منطق برنامه وجود دارد.---
### ✅ نتیجهگیری:
استفاده از
toggle
با پارامتر force
مزایای زیر را به همراه دارد:* کاهش منطق اضافی (نیازی به شرطهای جداگانه نیست)
* کاهش حجم کد (فقط یک خط کد بهجای چندین خط شرطی)
* کاهش خطا (جلوگیری از ناهماهنگی بین وضعیت UI و دادهها)
در مجموع، روشی ساده و مؤثر برای همگامسازی دقیق وضعیت عناصر با منطق برنامه است. 👍
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
❤1👍1
### انواع رشتهای قالبدار (Template Literal Types) در TypeScript: چرا به آنها نیاز داریم؟ 🤨
با آنکه این قابلیتها بهطور مکرر استفاده نمیشوند، اما میتوانند حل برخی مسائل خاص را بسیار سادهتر کنند — مسائلی مانند تولید کلیدها یا مدیریت مسیرها.
---
### ❓ این قابلیت چیست؟
انواع رشتهای قالبدار در TypeScript این امکان را میدهند که رشتههایی با ساختار پویا بسازیم، با استفاده از ساختار
#### نمونه:
در اینجا، نوع
---
### 🧑💻 این ویژگی چه زمانی مفید است؟
#### ✔️ تولید کلیدها:
زمانی که نیاز است چندین کلید با ساختار یکسان تولید شود، میتوان با استفاده از رشتههای قالبدار، از تکرار و خطاهای احتمالی جلوگیری کرد.
---
#### ✔️ کار با مسیرها و URLها:
در مواردی که نیاز است مسیرهایی با بخشهای پویا تعریف شوند — مانند مسیرهای کاربری یا API.
---
#### ✔️ تولید مقادیر خاص و کنترلشده:
زمانی که بخواهیم رشتههایی با الگوهای خاص و پیشوندهای مشخص داشته باشیم و سایر مقادیر را مجاز ندانیم.
---
### ✅ جمعبندی:
استفاده از رشتههای قالبدار در TypeScript این امکان را فراهم میکند که رشتههایی با ساختار مشخص و الگوهای ثابت را با دقت و ایمنی بالا نوعدهی کنیم. این ویژگی بهویژه در پروژههایی که نیاز به کار با دادههای پویا اما ساختاریافته دارند، بسیار کاربردی است و خطاهای رایج را به حداقل میرساند. 👍
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
با آنکه این قابلیتها بهطور مکرر استفاده نمیشوند، اما میتوانند حل برخی مسائل خاص را بسیار سادهتر کنند — مسائلی مانند تولید کلیدها یا مدیریت مسیرها.
---
### ❓ این قابلیت چیست؟
انواع رشتهای قالبدار در TypeScript این امکان را میدهند که رشتههایی با ساختار پویا بسازیم، با استفاده از ساختار
${}
برای ترکیب بخشهای مختلف. این کار به تعریف انواع دقیقتر، ایمنتر و انعطافپذیرتر کمک میکند.#### نمونه:
type Key = `${string}_action`;
در اینجا، نوع
Key
میتواند هر رشتهای باشد که با _action
پایان مییابد.---
### 🧑💻 این ویژگی چه زمانی مفید است؟
#### ✔️ تولید کلیدها:
زمانی که نیاز است چندین کلید با ساختار یکسان تولید شود، میتوان با استفاده از رشتههای قالبدار، از تکرار و خطاهای احتمالی جلوگیری کرد.
type Prefix = 'user' | 'admin';
type Action = 'create' | 'edit' | 'delete';
type ActionKey = `${Prefix}_${Action}`;
// 'user_create' | 'admin_edit' | و مانند آنها
---
#### ✔️ کار با مسیرها و URLها:
در مواردی که نیاز است مسیرهایی با بخشهای پویا تعریف شوند — مانند مسیرهای کاربری یا API.
type UserProfileUrl = `users/${string}/profile`;
// 'users/۱۲۳/profile' | 'users/john/profile' و غیره
---
#### ✔️ تولید مقادیر خاص و کنترلشده:
زمانی که بخواهیم رشتههایی با الگوهای خاص و پیشوندهای مشخص داشته باشیم و سایر مقادیر را مجاز ندانیم.
---
### ✅ جمعبندی:
استفاده از رشتههای قالبدار در TypeScript این امکان را فراهم میکند که رشتههایی با ساختار مشخص و الگوهای ثابت را با دقت و ایمنی بالا نوعدهی کنیم. این ویژگی بهویژه در پروژههایی که نیاز به کار با دادههای پویا اما ساختاریافته دارند، بسیار کاربردی است و خطاهای رایج را به حداقل میرساند. 👍
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
### Visual Viewport API: ردیابی بزرگنمایی و تغییرات ناحیهی دید 🤩
اگر تا به حال به این فکر کردهاید که چطور میتوان تغییرات در بزرگنمایی (zoom) صفحه یا واکنش به تغییر ابعاد پنجره در دستگاههای موبایل را شناسایی کرد، خبر خوبی برایتان دارم — من بهتازگی با API جالبی به نام Visual Viewport API آشنا شدم! 🎉
**Visual Viewport API** ابزاری است که به شما امکان میدهد بفهمید کاربر در حال حاضر سایت شما را *چگونه میبیند* و بتوانید رابط کاربری را متناسب با اقدامات او تنظیم کنید.
این API به شما دسترسی میدهد به ناحیهی دید بصری — یعنی آن بخش از صفحه که در لحظه روی نمایشگر دیده میشود، نه کل محتوای صفحه.
---
### با Visual Viewport API چه اطلاعاتی میتوان بهدست آورد؟
#### 🔍 ردیابی بزرگنمایی (Zoom)
از طریق ویژگی
---
#### 📏 تغییر اندازهی ناحیهی دید
زمانیکه اندازهی بخش قابلمشاهدهی صفحه تغییر میکند (برای مثال، هنگام بزرگنمایی یا چرخش صفحهنمایش)، میتوان از
---
#### ➡️ تشخیص جابهجایی ناحیهی دید
با استفاده از
---
### پشتیبانی از رویدادهای
این API از رویدادهای
---
### ✅ جمعبندی
با استفاده از Visual Viewport API میتوانید رابطهایی طراحی کنید که نسبت به رفتارهای کاربر مانند بزرگنمایی یا پیمایش (scroll) واکنش نشان دهند. این ویژگی بهویژه برای طراحی رابطهای موبایل بسیار ارزشمند است. 🙂
—
دموی این قابلیت را میتوانید در این لینک مشاهده کنید:
🔗 مشاهده کد در CodePen
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
اگر تا به حال به این فکر کردهاید که چطور میتوان تغییرات در بزرگنمایی (zoom) صفحه یا واکنش به تغییر ابعاد پنجره در دستگاههای موبایل را شناسایی کرد، خبر خوبی برایتان دارم — من بهتازگی با API جالبی به نام Visual Viewport API آشنا شدم! 🎉
**Visual Viewport API** ابزاری است که به شما امکان میدهد بفهمید کاربر در حال حاضر سایت شما را *چگونه میبیند* و بتوانید رابط کاربری را متناسب با اقدامات او تنظیم کنید.
این API به شما دسترسی میدهد به ناحیهی دید بصری — یعنی آن بخش از صفحه که در لحظه روی نمایشگر دیده میشود، نه کل محتوای صفحه.
---
### با Visual Viewport API چه اطلاعاتی میتوان بهدست آورد؟
#### 🔍 ردیابی بزرگنمایی (Zoom)
از طریق ویژگی
window.visualViewport.scale
میتوان تغییرات در سطح بزرگنمایی صفحه را شناسایی کرد. هر زمان کاربر صفحه را بزرگتر یا کوچکتر کند، این مقدار بهروز میشود.---
#### 📏 تغییر اندازهی ناحیهی دید
زمانیکه اندازهی بخش قابلمشاهدهی صفحه تغییر میکند (برای مثال، هنگام بزرگنمایی یا چرخش صفحهنمایش)، میتوان از
window.visualViewport.width
و window.visualViewport.height
برای دریافت ابعاد جدید استفاده کرد. این کار به تطبیق بهتر رابط کاربری با اندازههای مختلف کمک میکند.---
#### ➡️ تشخیص جابهجایی ناحیهی دید
با استفاده از
window.visualViewport.offsetLeft
و window.visualViewport.offsetTop
میتوان جابهجایی ناحیهی دید را نسبت به ابتدای صفحه پیگیری کرد. این قابلیت برای جایگذاری دقیق عناصر روی صفحه بسیار کاربردی است.---
### پشتیبانی از رویدادهای
resize
و scroll
این API از رویدادهای
resize
و scroll
نیز پشتیبانی میکند، که هنگام تغییر وضعیت ناحیهی دید فعال میشوند. این موضوع به شما امکان میدهد محتوای رابط کاربری را *بهصورت لحظهای* بهروزرسانی کنید — قابلیتی ایدهآل برای رابطهای پویا و تعاملی.---
### ✅ جمعبندی
با استفاده از Visual Viewport API میتوانید رابطهایی طراحی کنید که نسبت به رفتارهای کاربر مانند بزرگنمایی یا پیمایش (scroll) واکنش نشان دهند. این ویژگی بهویژه برای طراحی رابطهای موبایل بسیار ارزشمند است. 🙂
—
دموی این قابلیت را میتوانید در این لینک مشاهده کنید:
🔗 مشاهده کد در CodePen
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
codepen.io
Untitled
...
یکی از ویژگیهای CSS برای جدولها که اغلب نادیده گرفته میشود، اما میتواند بهطور چشمگیری کار شما را سادهتر کند:
##
این ویژگی تعیین میکند مرورگر چگونه ابعاد ستونها و سطرهای یک جدول را محاسبه کند.
###
با استفاده از این ویژگی، میتوان سرعت رندر جدول را افزایش داد و ظاهر آن را تحت کنترل قرار داد.
در حالت پیشفرض، مرورگر اندازهی ستونها را بر اساس محتوای درون آنها محاسبه میکند. این کار ممکن است مخصوصاً در جدولهای بزرگ، فرآیند رندر را کند کند.
اما با کمک
---
### مقادیر قابل استفاده برای
✔️
ابعاد ستونها بهصورت خودکار و بر اساس محتوای آنها تعیین میشود.
مناسب برای جدولهایی با محتوای پویا، اما ممکن است باعث کاهش سرعت رندر شود.
✔️
همهی ستونها دارای عرض ثابت خواهند بود، بدون توجه به محتوای داخلی آنها.
این گزینه رندر جدول را سریعتر کرده و کارایی را بهبود میبخشد، زیرا مرورگر از ابتدا از اندازههای تعیینشده استفاده میکند.
---
اگر جدول شما شامل دادههای زیادی است یا به ستونهایی با عرض یکسان نیاز دارید، استفاده از
🔗 [نمونه در CodePen](https://codepen.io/katrin_profrontend/pen/zxvKRPo)
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
##
table-layout
— کلیدی برای بهینهسازی جدولهااین ویژگی تعیین میکند مرورگر چگونه ابعاد ستونها و سطرهای یک جدول را محاسبه کند.
###
table-layout
دقیقاً چه میکند؟با استفاده از این ویژگی، میتوان سرعت رندر جدول را افزایش داد و ظاهر آن را تحت کنترل قرار داد.
در حالت پیشفرض، مرورگر اندازهی ستونها را بر اساس محتوای درون آنها محاسبه میکند. این کار ممکن است مخصوصاً در جدولهای بزرگ، فرآیند رندر را کند کند.
اما با کمک
table-layout
میتوان ابعاد ستونها را بهصورت ثابت تعیین کرد تا مرورگر دیگر نیازی به محاسبهی آنها نداشته باشد و از همان ابتدا، از اندازههای مشخصشده استفاده کند.---
### مقادیر قابل استفاده برای
table-layout
:✔️
auto
(مقدار پیشفرض):ابعاد ستونها بهصورت خودکار و بر اساس محتوای آنها تعیین میشود.
مناسب برای جدولهایی با محتوای پویا، اما ممکن است باعث کاهش سرعت رندر شود.
✔️
fixed
:همهی ستونها دارای عرض ثابت خواهند بود، بدون توجه به محتوای داخلی آنها.
این گزینه رندر جدول را سریعتر کرده و کارایی را بهبود میبخشد، زیرا مرورگر از ابتدا از اندازههای تعیینشده استفاده میکند.
---
اگر جدول شما شامل دادههای زیادی است یا به ستونهایی با عرض یکسان نیاز دارید، استفاده از
table-layout: fixed
بهترین انتخاب خواهد بود. 👍🔗 [نمونه در CodePen](https://codepen.io/katrin_profrontend/pen/zxvKRPo)
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
codepen.io
table-layout
...
❤3
### بهبود عملکرد رویدادهای پیمایش (Scroll) 👨🏫
بهتازگی با این هشدار مواجه شدم:
> "\[Violation] Added non-passive event listener to a scroll-blocking 'wheel' event. Consider marking event handler as 'passive' to make the page more responsive."
این پیام باعث شد رویکردم به مدیریت رویدادهای پیمایش را بازبینی کنم.
زمانی که با رویدادهایی مانند پیمایش با ماوس (
بهطور پیشفرض، مرورگرها میتوانند رفتار استاندارد (مانند پیمایش) را مسدود کنند، بهویژه اگر در تابع پردازشگر از
این مسأله ممکن است باعث تأخیر در واکنش رابط کاربری**، خصوصاً در دستگاههای همراه شود. 😔
---
### راهحل: استفاده از گزینهی `{ passive: true }` 🤨
با افزودن گزینهی `{ passive: true }` هنگام افزودن شنوندهی رویداد (Event Listener)، به مرورگر اطلاع میدهیم که قرار نیست رفتار پیشفرض را لغو کنیم.
در نتیجه، مرورگر میتواند بلافاصله اقدام به انجام رفتار استاندارد (مثل پیمایش) کند و منتظر اجرای کامل کد شما نماند.
```javascript
element.addEventListener('wheel', (event) => {
// کد مربوطه
}, { passive: true });
```
---
### چرا این موضوع اهمیت دارد؟
✔️ **افزایش سرعت واکنش رویدادها
مرورگر بلافاصله پیمایش را آغاز میکند و این باعث بهبود پاسخگویی رابط کاربری میشود — خصوصاً در تلفنهای هوشمند و تبلتها.
✔️ عدم انسداد رندر شدن صفحه
با استفاده از
---
### چند نکتهی مهم:
۱️⃣ مقدار پیشفرض `passive` برابر با false است
یعنی در حالت عادی میتوان از
اما مرورگرها در مورد برخی رویدادها مانند
۲️⃣ اگر شما `passive: true` را صراحتاً تعیین کنید و در تابع مربوطه از
---
### جمعبندی:
استفاده از گزینهی
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
بهتازگی با این هشدار مواجه شدم:
> "\[Violation] Added non-passive event listener to a scroll-blocking 'wheel' event. Consider marking event handler as 'passive' to make the page more responsive."
این پیام باعث شد رویکردم به مدیریت رویدادهای پیمایش را بازبینی کنم.
زمانی که با رویدادهایی مانند پیمایش با ماوس (
wheel
) یا حرکت لمسی (touchmove
) سروکار داریم، معمولاً چالشهایی در زمینهی عملکرد (Performance) به وجود میآید.بهطور پیشفرض، مرورگرها میتوانند رفتار استاندارد (مانند پیمایش) را مسدود کنند، بهویژه اگر در تابع پردازشگر از
event.preventDefault()
استفاده شود.این مسأله ممکن است باعث تأخیر در واکنش رابط کاربری**، خصوصاً در دستگاههای همراه شود. 😔
---
### راهحل: استفاده از گزینهی `{ passive: true }` 🤨
با افزودن گزینهی `{ passive: true }` هنگام افزودن شنوندهی رویداد (Event Listener)، به مرورگر اطلاع میدهیم که قرار نیست رفتار پیشفرض را لغو کنیم.
در نتیجه، مرورگر میتواند بلافاصله اقدام به انجام رفتار استاندارد (مثل پیمایش) کند و منتظر اجرای کامل کد شما نماند.
```javascript
element.addEventListener('wheel', (event) => {
// کد مربوطه
}, { passive: true });
```
---
### چرا این موضوع اهمیت دارد؟
✔️ **افزایش سرعت واکنش رویدادها
مرورگر بلافاصله پیمایش را آغاز میکند و این باعث بهبود پاسخگویی رابط کاربری میشود — خصوصاً در تلفنهای هوشمند و تبلتها.
✔️ عدم انسداد رندر شدن صفحه
با استفاده از
{ passive: true }
مرورگر دیگر منتظر اجرای کامل تابع پردازشگر نمیماند، که این موضوع باعث کاهش تأخیر و افزایش روانی حرکت صفحه میشود.---
### چند نکتهی مهم:
۱️⃣ مقدار پیشفرض `passive` برابر با false است
یعنی در حالت عادی میتوان از
event.preventDefault()
برای لغو رفتار پیشفرض استفاده کرد.اما مرورگرها در مورد برخی رویدادها مانند
wheel`، `touchmove
و touchstart
در سطوحی مثل window`، `document
و `document.body`، بهصورت خودکار passive را برابر با true قرار میدهند تا از ایجاد تاخیر جلوگیری شود.۲️⃣ اگر شما `passive: true` را صراحتاً تعیین کنید و در تابع مربوطه از
event.preventDefault()
استفاده نمایید، مرورگر این دستور را نادیده خواهد گرفت.---
### جمعبندی:
استفاده از گزینهی
{ passive: true }
یک تغییر ساده اما مؤثر برای بهبود روانی و واکنشپذیری اپلیکیشن است — بهویژه در سناریوهایی که با پیمایش و تعامل لمسی سروکار داریم. ✅#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
🔥1
استفاده از await در سطح بالای ماژولهای ES
نوشتن کدهای ناهمگام (asynchronous) در جاوااسکریپت تا چندی پیش یک محدودیت مهم داشت: کلیدواژهی await تنها درون یک تابع async قابل استفاده بود. این موضوع با معرفی ویژگی Top-Level Await در استاندارد ES2022 تغییر کرد؛ قابلیتی مدرن در ماژولهای ES که امکان اجرای الگوهای جدیدی از کد ناهمگام را در سطح ماژول فراهم میکند.
Top-Level Await چیست؟
بهطور سنتی، دستور await تنها درون توابع async معتبر بود:
اکنون با استفاده از Top-Level Await، میتوانید آن را در سطح بالای ماژول ES اجرا کنید:
در گذشته برای استفاده از await در سطح بالا، ناچار بودید آن را درون یک تابع ناهمگام خوداجرا (IIFE) بپیچید:
با Top-Level Await میتوانید با چنین کدهای زائد خداحافظی کنید و منطق ناهمگام خود را بهصورت مستقیم در بالاترین سطح ماژول بنویسید؛ کدی سادهتر، خواناتر و تمیزتر.
⚠️ نکته مهم
Top-Level Await فقط در ماژولهای جاوااسکریپت پشتیبانی میشود، نه در CommonJS (یعنی require) و نه در تگهای <script> سنتی که فاقد ویژگی type="module" هستند (زیرا این حالت در «مد کلاسیک» اجرا میشود). همچنین، فایلهای با پسوند .cjs در Node.js از آن پشتیبانی نمیکنند.
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
نوشتن کدهای ناهمگام (asynchronous) در جاوااسکریپت تا چندی پیش یک محدودیت مهم داشت: کلیدواژهی await تنها درون یک تابع async قابل استفاده بود. این موضوع با معرفی ویژگی Top-Level Await در استاندارد ES2022 تغییر کرد؛ قابلیتی مدرن در ماژولهای ES که امکان اجرای الگوهای جدیدی از کد ناهمگام را در سطح ماژول فراهم میکند.
Top-Level Await چیست؟
بهطور سنتی، دستور await تنها درون توابع async معتبر بود:
// ❌ خطای نحوی (SyntaxError) در خارج از تابع async
const result = await fetchData();
اکنون با استفاده از Top-Level Await، میتوانید آن را در سطح بالای ماژول ES اجرا کنید:
// ✅ این کد در یک ماژول ES قابل اجرا است
const result = await fetchData();
در گذشته برای استفاده از await در سطح بالا، ناچار بودید آن را درون یک تابع ناهمگام خوداجرا (IIFE) بپیچید:
(async () => {
const result = await fetchData();
})();
با Top-Level Await میتوانید با چنین کدهای زائد خداحافظی کنید و منطق ناهمگام خود را بهصورت مستقیم در بالاترین سطح ماژول بنویسید؛ کدی سادهتر، خواناتر و تمیزتر.
⚠️ نکته مهم
Top-Level Await فقط در ماژولهای جاوااسکریپت پشتیبانی میشود، نه در CommonJS (یعنی require) و نه در تگهای <script> سنتی که فاقد ویژگی type="module" هستند (زیرا این حالت در «مد کلاسیک» اجرا میشود). همچنین، فایلهای با پسوند .cjs در Node.js از آن پشتیبانی نمیکنند.
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
شکستن کلمات همراه با خط تیره 😉
موضوع ساده به نظر میرسد — وقتی یک کلمه طولانی در یک خط جا نمیشود، باید آن را با خط تیره به خط بعد منتقل کرد. اما چطور این کار را بهدرستی انجام دهیم تا هم ظاهر متن زیبا باشد و هم ساختار آن بههم نریزد؟
بیایید بررسی کنیم برای این کار در CSS چه نیاز داریم. ☺️
برای شکستن صحیح کلمات همراه با خط تیره، سه ویژگی اصلی مورد نیاز است:
✔️ overflow-wrap: break-word; — این ویژگی باعث میشود کلمات طولانی (مثل نشانیهای اینترنتی یا اصطلاحات پیچیده) در صورت کمبود فضا به خط بعد منتقل شوند.
✔️ word-break: break-word; — این ویژگی اجازه میدهد کلمات در نقاط مناسب نیز شکسته شوند، اگر در یک خط جا نشوند.
✔️ hyphens: auto; — مسئول اضافه کردن خودکار خط تیره هنگام شکستن کلمات است، بر اساس قواعد زبان مورد استفاده.
نمونه کد:
حالا همهچیز طبق قواعد زبان کار خواهد کرد: کلمات همراه با خط تیره شکسته میشوند و در عین حال متن، منظم و زیبا باقی میماند. 👍
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
موضوع ساده به نظر میرسد — وقتی یک کلمه طولانی در یک خط جا نمیشود، باید آن را با خط تیره به خط بعد منتقل کرد. اما چطور این کار را بهدرستی انجام دهیم تا هم ظاهر متن زیبا باشد و هم ساختار آن بههم نریزد؟
بیایید بررسی کنیم برای این کار در CSS چه نیاز داریم. ☺️
برای شکستن صحیح کلمات همراه با خط تیره، سه ویژگی اصلی مورد نیاز است:
✔️ overflow-wrap: break-word; — این ویژگی باعث میشود کلمات طولانی (مثل نشانیهای اینترنتی یا اصطلاحات پیچیده) در صورت کمبود فضا به خط بعد منتقل شوند.
✔️ word-break: break-word; — این ویژگی اجازه میدهد کلمات در نقاط مناسب نیز شکسته شوند، اگر در یک خط جا نشوند.
✔️ hyphens: auto; — مسئول اضافه کردن خودکار خط تیره هنگام شکستن کلمات است، بر اساس قواعد زبان مورد استفاده.
نمونه کد:
.text {
overflow-wrap: break-word; /* اجازه شکستن کلمات طولانی */
word-break: break-word; /* شکستن کلمات در نقاط مناسب */
hyphens: auto; /* افزودن خودکار خط تیره هنگام شکستن */
}
حالا همهچیز طبق قواعد زبان کار خواهد کرد: کلمات همراه با خط تیره شکسته میشوند و در عین حال متن، منظم و زیبا باقی میماند. 👍
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
یادآوری دربارهی `.setProperty()` و متغیرهای CSS 😉
همهی ما متد `.setProperty()` میشناسیم و معمولاً زمانی به یادش میافتیم که لازم باشد یک ویژگی CSS را مستقیماً از طریق JavaScript تغییر دهیم.
اما بهراحتی میتوان فراموش کرد که با همین متد میتوان متغیرهای CSS را نیز تغییر داد — و این در بسیاری موارد بسیار کارآمدتر است.
برای نمونه، یک متغیر سراسری در `:root`:
و در JavaScript:
اکنون تمام عناصری که مقدار
کجا استفاده از متغیرها از طریق `.setProperty()` بیشتر به چشم میآید؟
✔️ انیمیشنها — تنها با تغییر یک متغیر، تمام استایلهای مرتبط بهصورت روان و از طریق CSS transition بهروز میشوند.
✔️ استفاده در content — میتوان متن یا نمادی را در یک متغیر ذخیره کرد و آن را بهصورت پویا تغییر داد.
در نتیجه، `.setProperty()` تنها برای تغییر ویژگیها نیست، بلکه ابزاری قدرتمند برای مدیریت متغیرهای CSS نیز بهشمار میرود ⚡️
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
همهی ما متد `.setProperty()` میشناسیم و معمولاً زمانی به یادش میافتیم که لازم باشد یک ویژگی CSS را مستقیماً از طریق JavaScript تغییر دهیم.
اما بهراحتی میتوان فراموش کرد که با همین متد میتوان متغیرهای CSS را نیز تغییر داد — و این در بسیاری موارد بسیار کارآمدتر است.
برای نمونه، یک متغیر سراسری در `:root`:
:root {
--main-color: #333;
}
و در JavaScript:
// تغییر خود متغیر، نه ویژگی مستقیم
document.documentElement.style.setProperty('--main-color', '#ff6600');
اکنون تمام عناصری که مقدار
color: var(--main-color)
دارند، بهطور خودکار مقدار جدید را دریافت میکنند. 👍کجا استفاده از متغیرها از طریق `.setProperty()` بیشتر به چشم میآید؟
✔️ انیمیشنها — تنها با تغییر یک متغیر، تمام استایلهای مرتبط بهصورت روان و از طریق CSS transition بهروز میشوند.
✔️ استفاده در content — میتوان متن یا نمادی را در یک متغیر ذخیره کرد و آن را بهصورت پویا تغییر داد.
.btn::after {
content: var(--btn-label);
}
btn.style.setProperty('--btn-label', '"✓"');
در نتیجه، `.setProperty()` تنها برای تغییر ویژگیها نیست، بلکه ابزاری قدرتمند برای مدیریت متغیرهای CSS نیز بهشمار میرود ⚡️
#️⃣#tip #css
👥@IR_javascript_group
🆔@IR_javascript
👍1
من همیشه فکر میکردم توسعهی فرانتاند بهمراتب دشوارتر از بکاند است، اما توضیح این موضوع برای سایر توسعهدهندگان همیشه سخت بود. امروز خواستم نظر یک مدل زبانی (که بهنوعی نمایندهی «نظر کلی کارشناسان» است) را بررسی کنم.
نتیجه جالب بود:
توسعهی فرانتاند برای انسانها سختتر است، زیرا بکاند بیشتر ماهیتی ریاضی و مبتنی بر قواعد دارد و درک آن چندان دشوار نیست؛ همهچیز با فرمولها و الگوهای قابل پیشبینی پیش میرود.
اما فرانتاند؟ اینجا قیاس بینظیری مطرح شد: زیستشناسی!
🔹 مقیاسپذیری بکاند: شبیه ریاضیات؛ با افزودن نودهای بیشتر، شارد کردن پایگاه داده یا بهینهسازی کوئریها، سیستم طبق فرمولها و قوانین قابلپیشبینی رشد میکند.
🔹 تغییرات فرانتاند: شبیه زیستشناسی؛ جهشهای کوچک (مثل دستگاه جدید، ویژگی تازهی مرورگر یا نیاز متفاوت در تجربهی کاربری) رفتاری نوظهور، اغلب آشفته و موردی ایجاد میکنند که باید تکبهتک با آنها سازگار شد.
زیستشناسی بسیار پیچیدهتر از ریاضیات است — زیرا ریاضیات قانونمند و قطعی است، اما زیستشناسی پدیدهای نوظهور، پر از استثنا، وابسته به زمینه و همواره در حال تغییر.
به همین دلیل است که فرانتاند (شبیه زیستشناسی) برای انسانها بهمراتب شلوغتر و دشوارتر به نظر میرسد، حتی اگر بکاند (شبیه ریاضیات) از نظر انتزاعی ژرفتر باشد.
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
نتیجه جالب بود:
توسعهی فرانتاند برای انسانها سختتر است، زیرا بکاند بیشتر ماهیتی ریاضی و مبتنی بر قواعد دارد و درک آن چندان دشوار نیست؛ همهچیز با فرمولها و الگوهای قابل پیشبینی پیش میرود.
اما فرانتاند؟ اینجا قیاس بینظیری مطرح شد: زیستشناسی!
🔹 مقیاسپذیری بکاند: شبیه ریاضیات؛ با افزودن نودهای بیشتر، شارد کردن پایگاه داده یا بهینهسازی کوئریها، سیستم طبق فرمولها و قوانین قابلپیشبینی رشد میکند.
🔹 تغییرات فرانتاند: شبیه زیستشناسی؛ جهشهای کوچک (مثل دستگاه جدید، ویژگی تازهی مرورگر یا نیاز متفاوت در تجربهی کاربری) رفتاری نوظهور، اغلب آشفته و موردی ایجاد میکنند که باید تکبهتک با آنها سازگار شد.
زیستشناسی بسیار پیچیدهتر از ریاضیات است — زیرا ریاضیات قانونمند و قطعی است، اما زیستشناسی پدیدهای نوظهور، پر از استثنا، وابسته به زمینه و همواره در حال تغییر.
به همین دلیل است که فرانتاند (شبیه زیستشناسی) برای انسانها بهمراتب شلوغتر و دشوارتر به نظر میرسد، حتی اگر بکاند (شبیه ریاضیات) از نظر انتزاعی ژرفتر باشد.
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
🤔1
استفاده از `distinctUntilChanged` و `debounceTime`: بهینهسازی جستجو 👩💻
وقتی فرم ایجاد میکنیم، مهم است که از ارسال درخواستهای غیرضروری به سرور جلوگیری کنیم. دو اپراتور RxJS به نامهای `debounceTime` و `distinctUntilChanged` در این زمینه به ما کمک میکنند:
* ✔️
* ✔️
### مثال:
### عملکرد هر اپراتور:
⭐️
⭐️
---
✅ نتیجه: ترکیب این دو اپراتور به شما کمک میکند کنترل بهتری روی درخواستها در فرمهای جستجو داشته باشید، عملکرد را بهبود بخشید و بار روی سرور را کاهش دهید. 😉
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
وقتی فرم ایجاد میکنیم، مهم است که از ارسال درخواستهای غیرضروری به سرور جلوگیری کنیم. دو اپراتور RxJS به نامهای `debounceTime` و `distinctUntilChanged` در این زمینه به ما کمک میکنند:
* ✔️
debounceTime
اجرای عملیات را با تأخیر انجام میدهد.* ✔️
distinctUntilChanged
مقادیر تکراری را نادیده میگیرد.### مثال:
this.searchForm.controls.searchField.valueChanges
.pipe(
debounceTime(300), // صبر میکنیم ۳۰۰ میلیثانیه بعد از آخرین ورودی
distinctUntilChanged() // مقادیر تکراری را نادیده میگیریم
)
.subscribe(searchTerm => {
console.log('درخواست به سرور:', searchTerm);
this.searchData(searchTerm); // ارسال درخواست
});
### عملکرد هر اپراتور:
⭐️
debounceTime(300)
— ارسال درخواست را ۳۰۰ میلیثانیه بعد از آخرین ورودی به تأخیر میاندازد. این کار باعث میشود برای هر کاراکتر یک درخواست ارسال نشود، که مخصوصاً هنگام تایپ سریع بسیار مفید است.⭐️
distinctUntilChanged()
— تضمین میکند که درخواست تنها وقتی مقدار تغییر کند ارسال شود. اگر کاربر همان عبارت جستجو را دوباره وارد کند، درخواست تکراری ارسال نخواهد شد.---
✅ نتیجه: ترکیب این دو اپراتور به شما کمک میکند کنترل بهتری روی درخواستها در فرمهای جستجو داشته باشید، عملکرد را بهبود بخشید و بار روی سرور را کاهش دهید. 😉
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript