لیستی از سایت ها و کانال هایی که در آنها می توانید قالب های رایگان پیدا کنید
https://themelock.com/eng/
https://nullmart.net/
https://scriptmafia.org/category/templates/
https://t.me/ingressive4good
https://t.me/themelock
https://t.me/nullmart
https://t.me/DesignGoodies
https://t.me/EnvatoFreebies
https://t.me/michollo
اگر مورد دیگری را میشناسید در بخش نظرات مطرح کنید
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
https://themelock.com/eng/
https://nullmart.net/
https://scriptmafia.org/category/templates/
https://t.me/ingressive4good
https://t.me/themelock
https://t.me/nullmart
https://t.me/DesignGoodies
https://t.me/EnvatoFreebies
https://t.me/michollo
اگر مورد دیگری را میشناسید در بخش نظرات مطرح کنید
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
👍4
This media is not supported in your browser
VIEW IN TELEGRAM
Flexboxdefense
یک بازی در سبک Tower Defense است که در آن باید برجها را با استفاده از فِلکسباکس به درستی قرار دهید تا از حملات دفاع کنید.
🔗http://www.flexboxdefense.com/
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
یک بازی در سبک Tower Defense است که در آن باید برجها را با استفاده از فِلکسباکس به درستی قرار دهید تا از حملات دفاع کنید.
🔗http://www.flexboxdefense.com/
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
👏4
دینامیک کردن نامهای ویژگیها 🥸
وقتی درباره ویژگیهای دینامیک در جاوااسکریپت صحبت میکنیم، معمولاً به انعطافپذیری و راحتی آن فکر میکنیم: میتوانیم اشیاء را در حین اجرا ایجاد کنیم بدون اینکه نیاز داشته باشیم همه کلیدها را از پیش بدانیم. اما مانند هر ابزار دیگری، مهم است که بدانیم کی از آن استفاده کنیم و چگونه از اشتباهات جلوگیری کنیم.
➡️ کی مفید است؟
به عنوان مثال، در هنگام توسعه سیستمهای ردیابی رویدادها یا لاگها، معمولاً نیاز است که هر شیء کلید منحصر به فردی داشته باشد – برای مثال، بر اساس زمان وقوع رویداد. به جای ایجاد یک شیء استاتیک، میتوان ویژگی دینامیک با برچسب زمانی که برای هر رویداد منحصر به فرد است، اضافه کرد.
➡️ چه نکاتی باید در نظر گرفته شود؟
✨ یکی از مشکلات بالقوه با کلیدهای دینامیک، امکان نداشتن ویژگی است. به عنوان مثال، در دسترسی به object[dynamicKey]، جاوااسکریپت تضمین نمیکند که این کلید واقعاً در شیء موجود باشد و در صورتی که نباشد، undefined را برمیگرداند؛
✨ زمانی که کلیدها بر اساس متغیرها ایجاد میشوند، کد برای کسانی که بعداً آن را میخوانند کمتر قابل پیشبینی میشود. بنابراین، برای اینکه کد قابل فهم باقی بماند، نباید از ویژگیهای دینامیک به طور افراطی استفاده کرد و باید ساختار دادهها مستند شود.
در نهایت، ویژگیهای دینامیک میتوانند زمان زیادی را برای شما صرفهجویی کرده و کد را سادهتر کنند، اما تنها در صورتی که با دقت از آنها استفاده کنید. 👍
پ.ن. پیادهسازیها برای درک راحتتر ساده شدهاند :)
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
وقتی درباره ویژگیهای دینامیک در جاوااسکریپت صحبت میکنیم، معمولاً به انعطافپذیری و راحتی آن فکر میکنیم: میتوانیم اشیاء را در حین اجرا ایجاد کنیم بدون اینکه نیاز داشته باشیم همه کلیدها را از پیش بدانیم. اما مانند هر ابزار دیگری، مهم است که بدانیم کی از آن استفاده کنیم و چگونه از اشتباهات جلوگیری کنیم.
➡️ کی مفید است؟
به عنوان مثال، در هنگام توسعه سیستمهای ردیابی رویدادها یا لاگها، معمولاً نیاز است که هر شیء کلید منحصر به فردی داشته باشد – برای مثال، بر اساس زمان وقوع رویداد. به جای ایجاد یک شیء استاتیک، میتوان ویژگی دینامیک با برچسب زمانی که برای هر رویداد منحصر به فرد است، اضافه کرد.
function logEvent(event) {
const timestamp = new Date().toISOString();
return {
[timestamp]: event,
};
}
console.log(logEvent("User logged in")); // { '2024-11-11T09:19:04.939Z': 'User logged in' }
➡️ چه نکاتی باید در نظر گرفته شود؟
✨ یکی از مشکلات بالقوه با کلیدهای دینامیک، امکان نداشتن ویژگی است. به عنوان مثال، در دسترسی به object[dynamicKey]، جاوااسکریپت تضمین نمیکند که این کلید واقعاً در شیء موجود باشد و در صورتی که نباشد، undefined را برمیگرداند؛
✨ زمانی که کلیدها بر اساس متغیرها ایجاد میشوند، کد برای کسانی که بعداً آن را میخوانند کمتر قابل پیشبینی میشود. بنابراین، برای اینکه کد قابل فهم باقی بماند، نباید از ویژگیهای دینامیک به طور افراطی استفاده کرد و باید ساختار دادهها مستند شود.
در نهایت، ویژگیهای دینامیک میتوانند زمان زیادی را برای شما صرفهجویی کرده و کد را سادهتر کنند، اما تنها در صورتی که با دقت از آنها استفاده کنید. 👍
پ.ن. پیادهسازیها برای درک راحتتر ساده شدهاند :)
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
👍1
گوگل کروم بازی دایناسور (T-Rex) را بهصورت بیپایان در حالت عدم اتصال به اینترنت ارائه میدهد. بیایید کلاه هکرهایمان را به سر بگذاریم و کمی با این بازی دستکاری کنیم.
اگر قادر به مشاهده صفحه "بدون اینترنت" نیستید، یک تب جدید باز کرده و عبارت chrome://dino را وارد کنید و سپس اینتر بزنید. سپس کد زیر را در کنسول پیست کنید
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
اگر قادر به مشاهده صفحه "بدون اینترنت" نیستید، یک تب جدید باز کرده و عبارت chrome://dino را وارد کنید و سپس اینتر بزنید. سپس کد زیر را در کنسول پیست کنید
function dispatchKey(type, key) {
document.dispatchEvent(new KeyboardEvent(type, {keyCode: key}));
}
setInterval(function () {
const KEY_CODE_SPACE_BAR = 32
const KEY_CODE_ARROW_DOWN = 40
const CANVAS_HEIGHT = Runner.instance_.dimensions.HEIGHT
const DINO_HEIGHT = Runner.instance_.tRex.config.HEIGHT
const obstacle = Runner.instance_.horizon.obstacles[0]
const speed = Runner.instance_.currentSpeed
if (obstacle) {
const w = obstacle.width
const x = obstacle.xPos // measured from left of canvas
const y = obstacle.yPos // measured from top of canvas
const yFromBottom = CANVAS_HEIGHT - y - obstacle.typeConfig.height
const isObstacleNearby = x < 25 * speed - w / 2
if (isObstacleNearby) {
if (yFromBottom > DINO_HEIGHT) {
// Pterodactyl going from above, do nothing
} else if (y > CANVAS_HEIGHT / 2) {
// Jump
dispatchKey("keyup", KEY_CODE_ARROW_DOWN)
dispatchKey("keydown", KEY_CODE_SPACE_BAR)
} else {
// Duck
dispatchKey("keydown", KEY_CODE_ARROW_DOWN)
}
}
}
}, Runner.instance_.msPerFrame);
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
👍3
ویدیو دوبله شده در مورد شش سبک محبوب معماری API [+لینک]
با میلیاردها درخواست API که روزانه انجام میشود، درک سبکهای معماری API اهمیت بیشتری پیدا کرده است. این سبکها ستون فقرات دنیای دیجیتال امروزی را تشکیل میدهند و واسطهای برنامهنویسی کاربردی (API) نقش کلیدی در توسعه نرمافزارهای مدرن دارند.
🔗https://aparat.com/v/uka260b
#️⃣#tip #dub
👥@IR_javascript_group
🆔@IR_javascript
با میلیاردها درخواست API که روزانه انجام میشود، درک سبکهای معماری API اهمیت بیشتری پیدا کرده است. این سبکها ستون فقرات دنیای دیجیتال امروزی را تشکیل میدهند و واسطهای برنامهنویسی کاربردی (API) نقش کلیدی در توسعه نرمافزارهای مدرن دارند.
🔗https://aparat.com/v/uka260b
#️⃣#tip #dub
👥@IR_javascript_group
🆔@IR_javascript
زمانی مدالها عنصر نسبتاً پیچیدهای بودند که باعث ایجاد تعداد زیادی کتابخانه برای نمایش آنها شد .
امروز، HTML <dialog> این کار را بهراحتی و بدون دردسر انجام میدهد.
در اینجا یک مثال از یک مدال در ۳۰ خط کد با اورلی، امکان بسته شدن با کلیک خارج از پنجره و فشردن دکمه ESC، همراه با پشتیبانی از دسترسپذیری و دیگر استانداردهای W3C آورده شده است:
استفاده:
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
امروز، HTML <dialog> این کار را بهراحتی و بدون دردسر انجام میدهد.
در اینجا یک مثال از یک مدال در ۳۰ خط کد با اورلی، امکان بسته شدن با کلیک خارج از پنجره و فشردن دکمه ESC، همراه با پشتیبانی از دسترسپذیری و دیگر استانداردهای W3C آورده شده است:
<script setup lang="ts">
import { ref } from "vue";
const dialog = ref(null);
function show() {
dialog.value.showModal();
}
function close() {
dialog.value.close();
}
function onClick($event) {
if ($event.target === dialog.value) {
dialog.value.close();
}
}
defineExpose({ show, close });
</script>
<template>
<dialog
ref="dialog"
role="textbox"
tabindex="0"
@click="onClick"
>
<slot />
</dialog>
</template>
<style scoped></style>
استفاده:
const holaModal = useTemplateRef("holaModal");
// holaModal.value.show();
...
<ModalDialog ref="holaModal">
<div>Hola!</div>
<button @click="holaModal.close()">
Close
</button>
</ModalDialog>
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
👍1
This media is not supported in your browser
VIEW IN TELEGRAM
شهادت مظلومانه دخت پیامبر ام ابیها مظلومه عالم خلقت حضرت فاطمه الزهرا سلام الله بر تمامی شیعیان تسلیت باد .
#️⃣#event
👥@IR_javascript_group
🆔@IR_javascript
#️⃣#event
👥@IR_javascript_group
🆔@IR_javascript
❤15
سوئیچ روان بین ویدیو و پیشنمایش کوچک 🎥
تصور کنید: شما یک ویدیو در صفحه دارید و کاربر شروع به تماشای آن میکند. اما مشکلی پیش میآید—کاربر صفحه را اسکرول میکند و ویدیو از دید خارج میشود. در این مواقع معمولاً ویدیو متوقف میشود که ممکن است باعث سردرگمی کاربر شود. حال اگر بهجای این اتفاق، ویدیو بهطور خودکار در یک پیشنمایش کوچک در گوشهی صفحه ادامه پیدا کند، چطور؟
امروز، راهکاری برای این مشکل با استفاده از جاوااسکریپت و IntersectionObserver به اشتراک میگذارم. 🚀
چه چیزی را میخواهیم پیادهسازی کنیم؟ ✅ ویدیو در بخش اصلی در حال پخش باقی میماند تا زمانی که در دید کاربر باشد؛
✅ وقتی ویدیو از دید خارج میشود، به شکل یک پیشنمایش کوچک در گوشهی صفحه ظاهر شده و به پخش خود ادامه میدهد؛
✅ پیشنمایش کوچک با ویدیوی اصلی همگام است: زمان فعلی و وضعیت (پخش/توقف) کاملاً با هم هماهنگ هستند؛
✅ وقتی ویدیوی اصلی دوباره به دید کاربر برمیگردد، مجدداً فعال میشود و پیشنمایش کوچک محو میشود.
و تمام این فرآیند بهصورت روان و بدون اشکال انجام میشود.
نمونه کد در لینک زیر
🔗 https://codepen.io/katrin_profrontend/pen/ogvjJVx
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
تصور کنید: شما یک ویدیو در صفحه دارید و کاربر شروع به تماشای آن میکند. اما مشکلی پیش میآید—کاربر صفحه را اسکرول میکند و ویدیو از دید خارج میشود. در این مواقع معمولاً ویدیو متوقف میشود که ممکن است باعث سردرگمی کاربر شود. حال اگر بهجای این اتفاق، ویدیو بهطور خودکار در یک پیشنمایش کوچک در گوشهی صفحه ادامه پیدا کند، چطور؟
امروز، راهکاری برای این مشکل با استفاده از جاوااسکریپت و IntersectionObserver به اشتراک میگذارم. 🚀
چه چیزی را میخواهیم پیادهسازی کنیم؟ ✅ ویدیو در بخش اصلی در حال پخش باقی میماند تا زمانی که در دید کاربر باشد؛
✅ وقتی ویدیو از دید خارج میشود، به شکل یک پیشنمایش کوچک در گوشهی صفحه ظاهر شده و به پخش خود ادامه میدهد؛
✅ پیشنمایش کوچک با ویدیوی اصلی همگام است: زمان فعلی و وضعیت (پخش/توقف) کاملاً با هم هماهنگ هستند؛
✅ وقتی ویدیوی اصلی دوباره به دید کاربر برمیگردد، مجدداً فعال میشود و پیشنمایش کوچک محو میشود.
و تمام این فرآیند بهصورت روان و بدون اشکال انجام میشود.
نمونه کد در لینک زیر
🔗 https://codepen.io/katrin_profrontend/pen/ogvjJVx
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
codepen.io
Плавное переключения между видео и мини-превью
...
👍4
در اینجا فهرستی از جایگزینهای رایگان، متنباز، در دسترس و قابل میزبانی شخصی برای برخی از سرویسها و نرمافزارهای پولی آورده شده است:
Notion → Appflowy
Zoom → Jitsi
Jira → Plane
Airtable → NocoDB
Vercel → Coolify
Heroku → Dokku
Firebase → Pocketbase، Appwrite، Convex، Supabase
Shopify → Prestashop
GitHub → GitLab
Slack → Mattermost
Salesforce CRM → ERPNext
Dropbox → NextCloud
Mailchimp → Mautic
Trello → Wekan
Docusign → Docuseal
Calendly → Cal.com
Datadog → Prometheus
Google Analytics → Matomo
Microsoft Office 365 → LibreOffice
Asana → OpenProject
این جایگزینها ابزارهایی قدرتمند و انعطافپذیر برای صرفهجویی در هزینهها هستند و امکان کنترل بیشتر بر دادهها را نیز فراهم میکنند.
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
Notion → Appflowy
Zoom → Jitsi
Jira → Plane
Airtable → NocoDB
Vercel → Coolify
Heroku → Dokku
Firebase → Pocketbase، Appwrite، Convex، Supabase
Shopify → Prestashop
GitHub → GitLab
Slack → Mattermost
Salesforce CRM → ERPNext
Dropbox → NextCloud
Mailchimp → Mautic
Trello → Wekan
Docusign → Docuseal
Calendly → Cal.com
Datadog → Prometheus
Google Analytics → Matomo
Microsoft Office 365 → LibreOffice
Asana → OpenProject
این جایگزینها ابزارهایی قدرتمند و انعطافپذیر برای صرفهجویی در هزینهها هستند و امکان کنترل بیشتر بر دادهها را نیز فراهم میکنند.
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
❤3
نسخه ۴.۵.۰ از Vue Router منتشر شد! 🎉
نکته برجسته:
به پیشنهاد ایوان یو، یک پراپ جدید به نام view-transition به کامپوننت RouterLink اضافه شده است. این پراپ از API انتقال نمای بومی (View Transitions API) استفاده میکند که برای انتقال بین مسیرها (routes) طراحی شده است.
نمونه استفاده:
قابلیت سفارشیسازی:
انیمیشنهای مربوط به این API را میتوان با استایلهای CSS به دلخواه تنظیم کرد.
مقایسه با قابلیتهای قبلی:
سرعت بیشتر: ممکن است سریعتر از کامپوننت <Transition> باشد.
سادگی در کدنویسی: نسبت به استفاده از ساختار router-view با <Transition>، نوشتار کوتاهتر و سادهتری دارد.
محدودیتها: برای انتقالهای ساده مناسب است، اما به اندازه <Transition> قدرتمند و انعطافپذیر نیست.
منبع:
View Transitions API - MDN
این قابلیت جدید تجربه کار با Vue Router را برای انتقالهای ساده و کارآمدتر بهبود میبخشد. 🌟
#️⃣#npm_module
👥@IR_javascript_group
🆔@IR_javascript
نکته برجسته:
به پیشنهاد ایوان یو، یک پراپ جدید به نام view-transition به کامپوننت RouterLink اضافه شده است. این پراپ از API انتقال نمای بومی (View Transitions API) استفاده میکند که برای انتقال بین مسیرها (routes) طراحی شده است.
نمونه استفاده:
<template>
<RouterLink to="/some-page" view-transition>
رفتن به صفحهای دیگر
</RouterLink>
</template>
قابلیت سفارشیسازی:
انیمیشنهای مربوط به این API را میتوان با استایلهای CSS به دلخواه تنظیم کرد.
مقایسه با قابلیتهای قبلی:
سرعت بیشتر: ممکن است سریعتر از کامپوننت <Transition> باشد.
سادگی در کدنویسی: نسبت به استفاده از ساختار router-view با <Transition>، نوشتار کوتاهتر و سادهتری دارد.
محدودیتها: برای انتقالهای ساده مناسب است، اما به اندازه <Transition> قدرتمند و انعطافپذیر نیست.
منبع:
View Transitions API - MDN
این قابلیت جدید تجربه کار با Vue Router را برای انتقالهای ساده و کارآمدتر بهبود میبخشد. 🌟
#️⃣#npm_module
👥@IR_javascript_group
🆔@IR_javascript
👍3🔥1
به کاربران اجازه دهید تا بهطور بصری عناصر DOM را انتخاب کنند
از viselect استفاده کنید اگر تعداد زیادی عنصر دارید و میخواهید کاربران بتوانند آنها را به صورت گروهی، تکتک یا حتی در چندین گروه انتخاب کنند. میتوانید از آن به صورت مستقل استفاده کنید یا آن را با P/React یا Vue.js یکپارچه کنید.
ویژگیهای کلیدی:
🌟 بستهبندی مدرن
🔩 اندازه فشرده (~۴ کیلوبایت)
👌 استفاده ساده
⚡️ بهینهسازی بالا
✔️ بدون وابستگیها
📱 پشتیبانی از دستگاههای موبایل و ورودی لمسی
🖱 پشتیبانی از اسکرول عمودی و افقی
🖼 یکپارچگی با فریمورکهای اصلی (در حال توسعه)
🔗https://github.com/Simonwep/selection
#️⃣#npm_module
👥@IR_javascript_group
🆔@IR_javascript
از viselect استفاده کنید اگر تعداد زیادی عنصر دارید و میخواهید کاربران بتوانند آنها را به صورت گروهی، تکتک یا حتی در چندین گروه انتخاب کنند. میتوانید از آن به صورت مستقل استفاده کنید یا آن را با P/React یا Vue.js یکپارچه کنید.
ویژگیهای کلیدی:
🌟 بستهبندی مدرن
🔩 اندازه فشرده (~۴ کیلوبایت)
👌 استفاده ساده
⚡️ بهینهسازی بالا
✔️ بدون وابستگیها
📱 پشتیبانی از دستگاههای موبایل و ورودی لمسی
🖱 پشتیبانی از اسکرول عمودی و افقی
🖼 یکپارچگی با فریمورکهای اصلی (در حال توسعه)
🔗https://github.com/Simonwep/selection
#️⃣#npm_module
👥@IR_javascript_group
🆔@IR_javascript
🤯3
این منبع به شما امکان میدهد تا نحوه استفاده و اصطلاحات مختلف فریمورکها را برای ویژگیهای مختلفی مانند واکنشگرایی، قالببندی، چرخه حیات، ترکیب، فرمها، استخراج دادهها و مسیریابی مقایسه کنید.
🔗https://component-party.dev/
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
🔗https://component-party.dev/
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
❤3👍2
برای استفاده از ویژگیهای جدید CSS و اعمال استایلها در مرورگرهایی که از آنها پشتیبانی نمیکنند، میتوان از supports استفاده کرد. همین کار را میتوان در جاوااسکریپت نیز انجام داد.
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
#️⃣#tip
👥@IR_javascript_group
🆔@IR_javascript
🔥3
Floating UI
یک کتابخانه کوچک است که به شما کمک میکند تا عناصر "شناور" مانند تولتیپها، پاپآپها، منوهای کشویی و موارد دیگر را ایجاد کنید.
🔗https://floating-ui.com/
#️⃣#npm_module
👥@IR_javascript_group
🆔@IR_javascript
یک کتابخانه کوچک است که به شما کمک میکند تا عناصر "شناور" مانند تولتیپها، پاپآپها، منوهای کشویی و موارد دیگر را ایجاد کنید.
🔗https://floating-ui.com/
#️⃣#npm_module
👥@IR_javascript_group
🆔@IR_javascript
👍2
اگر به دنبال (snippets) برای Vue در VS Code هستید، باید بدانید که میان حجم زیادی از گزینههای موجود، انتخاب مناسب میتواند چالشبرانگیز باشد.
یک گزینه مناسب می تواند Vue 3 VS Code Snippets باشد
🔗https://marketplace.visualstudio.com/items?itemName=exer7um.vue-3-vscode-snippets
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
یک گزینه مناسب می تواند Vue 3 VS Code Snippets باشد
🔗https://marketplace.visualstudio.com/items?itemName=exer7um.vue-3-vscode-snippets
#️⃣#tool
👥@IR_javascript_group
🆔@IR_javascript
👍1