Alireza 👨🏻‍💻
256 subscribers
180 photos
15 videos
2 files
36 links
Download Telegram
‏یه نکته فنی ساده برنامه‌نویسی که اصلا دقت نکرده بودم بهشو امروز فهمیدم.
‏باورش سخته ولی آدم سالیان سال هم برنامه‌نویس باشه باز برمیگرده عقب میبینه یه سری نکات ساده رو بلد نیست که ممکنه خیلی از تازه‌کارها بلدش باشن.
‏جالبه

Bardia
👍13
تبدیل nestjs به موشک سرعت

چند تا راه هست توی سطوح مختلف که میتونه باعث افزایش چشم گیر سرعت توی نست جی اس بشه که البته سرعت همونطور که میدونیم ابعاد مختلفی داره.
من چیزایی که خودم تحقیق کردم و دیدم رو مینویسم

مورد اول:
تبدیل http adapter از پیشفرض express به فستیفای
باعث افزایش ۲ الی ۵ برابری سرعت توی درخواست های rest api میشه
مورد دوم:
اضافه کردن کشینگ ردیس توی اینترسپتور ها، باعث میشه سرعت جواب دادن سرویس ها بیشتر بشه و response time خیلی کمتر بشه
مورد سوم:
فشرده سازی درخواست ها، باعث میشه ۱۰ تا ۲۰ درصد سرعت افزایش پیدا کنه، اگر فستیفای آداپتر استفاده میکنید از پکیج
@fastify/compress
میتونید استفاده کنید و اگر اکسپرس استفاده میکنید از پکیج
compress
میتونید استفاده کنید.
مورد چهارم: استفاده از پکیج cluster برای استفاده از هسته های مختلف سی پی یو
import cluster from 'cluster';
import { cpus } from 'os';

if (cluster.isPrimary) {
  cpus().forEach(() => cluster.fork());
} else {
  // bootstrap Nest app
}
اگه سی پی یو چند هسته ای باشه موازی سازی پردازش باعث افزایش سرعت خیلی چشم گیری میشه
مورد پنجم:
این یکی برای توسعس، استفاده از swc به عنوان بیلدر و کامپایلر به جای tsc پیشفرض باعث افزایش ۱۰ تا ۲۰ برابری سرعت توسعه میشه. swc کامپایلر بر پایه rust هستش

Amir Zalaghi
👍1
مفهوم abstraction یعنی چی؟

ا Abstraction یعنی پنهان کردن جزئیات غیرضروری و فقط نشان دادن چیزهای مهم.
یعنی وقتی با یه چیز کار می‌کنیم، فقط اون بخش‌هایی رو ببینیم که برای استفاده لازمن، نه اون‌هایی که برای پیاده‌سازی لازم بودن.

در کدنویسی، Abstraction یعنی اینکه ما:
بخش‌هایی از کد رو طوری طراحی می‌کنیم که فقط رفتارهای لازم رو expose کنن؛
ولی جزئیات درونی (پیاده‌سازی) رو پنهان کنن.

مثال:


class UserService {
private users = [];

addUser(name: string) {
this.users.push(name);
}

getAllUsers() {
return [...this.users];
}
}

اینجا:
بیرون از کلاس فقط addUser و getAllUsers در دسترس هستن.
کسی نمی‌دونه (و نباید بدونه) که users چطور ذخیره می‌شن، آیا در حافظه‌ان یا در دیتابیس.

خب فایدش چیه؟
وابستگی بین قسمت‌های مختلف برنامه کم میشه
می‌تونیم راحت‌تر کد رو تغییر بدیم یا تست کنیم
شلوغی‌ها تا جای ممکن کم میشه
👍2
What will happen?

const arr = [1, 2, 3]; arr[10] = 5; console.log(arr.length);
Anonymous Quiz
25%
3
10%
10
50%
11
15%
See answer
جاوااسکریپت یا تایپ‌اسکریپت؟ کِی از کدوم استفاده کنیم؟

یکی از سؤال‌های رایج بین برنامه‌نویس‌ها اینه که آیا باید پروژه رو با جاوااسکریپت شروع کنیم یا تایپ‌اسکریپت؟
پاسخ کوتاه اینه: بستگی به نوع پروژه و هدفت داره.


زمانی که جاوااسکریپت انتخاب بهتریه:
• پروژه کوچکه و نیاز به ساختار پیچیده نداره
• می‌خوای سریع نمونه اولیه (prototype) بسازی
• اعضای تیم هنوز با TypeScript آشنا نیستن
• قصد داری فقط سمت مرورگر (Frontend) کار سبک انجام بدی

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


زمانی که باید سراغ TypeScript بری:
• پروژه بزرگ یا بلندمدته
• تیم چندنفره داری و می‌خوای از اشتباهات زمان اجرا جلوگیری کنی
• نیاز به type safety و autocomplete قوی داری
• ساختار کدها باید قابل نگهداری و قابل توسعه باشه

TypeScript با اضافه کردن نوع‌دهی ایستا، خطاها رو قبل از اجرا نشون میده و کیفیت کد رو بالا می‌بره.


جمع‌بندی:
اگر هدفت سرعت و سادگیه، جاوااسکریپت انتخاب خوبیه.
اما اگر پایداری، مقیاس‌پذیری و خوانایی کد برات مهمه، TypeScript انتخاب منطقی‌تره.

در واقع، یادگیری هر دو ضروریه. جاوااسکریپت پایه است، TypeScript نسخه‌ی امن‌تر و حرفه‌ای‌تر اون.
👍1
موافقید؟
👍11👎1
بازنویسی کامپایلر TypeScript با Go

شرکت Microsoft اعلام کرده که در حال مهاجرت (port) یا بازنویسی کامپایلر TypeScript از جاوااسکریپت به زبان Go هستند.
هدف اصلی؟ بهبود چشمگیر عملکرد، کاهش زمان کامپایل و مصرف حافظه.


نکات کلیدی:
• کامپایلر فعلی TypeScript (tsc) تا امروز عمدتاً در جاوااسکریپت/TypeScript اجرا می‌شده؛ حالا پروژه‌ای تحت عنوان «native port» راه افتاده که کد در Go اجرا خواهد شد.
• بنچمارک‌های اولیه نشان میدن که سرعت کامپایل روی پروژه‌های بزرگ ممکنه ۱۰ برابر سریع‌تر بشه.
• این تغییر تأثیری بر نحوه‌ی استفاده برنامه‌نویس‌ها از TypeScript نداره؛ syntax و APIها ثابت می‌مونن. فقط پشتِ‌صحنه اجرا بهینه‌تر میشه.



چرا Go؟
چند دلیل مهم پشت انتخاب Go:
• پشتیبانی قدرتمند از هم‌زمانی (concurrency) که برای پردازش فایل‌های زیاد و تحلیل AST کامپایلر مهمه.
• جمع‌آوری خودکار حافظه (garbage collection) و ساختار داده‌ها که می‌تواند برای برنامه‌ای به پیچیدگی یک کامپایلر مناسب‌تر باشه.
• امکان پورت «تابع به تابع» (functionally similar) از کد قدیمی به کد جدید بدون بازنویسی کامل.



چه چیزی تغییر می‌کند؟
برای شما به عنوان توسعه‌دهنده‌ی TypeScript، تغییر عمده‌ای نیست.
کدی که تا حالا نوشتی همون کدی هست که خواهی نوشت.
ولی زمان ساخت پروژه‌ها، زمان پاسخگویی ابزارها و مصرف حافظه در پروژه‌های بزرگ بهتر خواهد شد.
👍2
پکیج: dotenv-expand
احتمالاً با dotenv آشنا هستین، پکیجی که متغیرهای محیطی رو از فایل .env لود می‌کنه.
اما اگه بخوایم توی .env از یه متغیر داخل متغیر دیگه استفاده کنیم، dotenv به‌صورت پیش‌فرض اینو ساپورت نمی‌کنه.

اینجا می‌تونیم از dotenv-expand استفاده کنیم.

APP_NAME=My-Project
APP_PATH=/var/www/${APP_NAME}

اینجا از APP_NAME تونستیم توی یک متغیر دیگه هم استفاده کنیم. فقط توی کد باید کد زیر رو اضافه کنیم:
import dotenv from "dotenv";
import dotenvExpand from "dotenv-expand";

const env = dotenv.config();
dotenvExpand.expand(env);

console.log(process.env.APP_PATH); // /var/www/My-Project


تمیزی و نظم فایل .env رو زیاد می‌کنه و جلوی تکرار بی مورد رو می‌گیره.
برای پروژه‌های چندمحیطی (dev, staging, prod) عالیه.
نیاز به تغییر در dotenv اصلی نداره.
👍1
بک اند یاد بگیرم یا نه ؟

روی صحبتم با کسایی هست که چندسالی تجربه موفق توی فرانت اند داشتن :

خیلی ها اعتقاد دارن باید یه مهارت رو یاد گرفت و توی همون عمیق شد و تا تهش رفت , تا حدی درسته اما دنیای وب خیلی گستردس خصوصا برای کسی که عاشقه کدنوشتن هستش و برنامه نویسی رو فقط به چشم یه شغل نگاه نمیکنه

به نظر من وقتی فرانت بلدی یاد گیری بک اند واست هم راحت تر میشه و هم دیده بهتری بهت میده خصوصا اگر زبان عوض نکنی و یه چیزی مثل node ,express یادبگیری

اگر فرانت‌اند کار هستی، یه روزی وقت بذار و سمت سرور رو هم کشف کن, قول می‌دم طرز نگاهت به کد برای همیشه تغییر کنه.

وقتی یادگیری بک‌اند رو شروع کردم، فکر می‌کردم فقط قراره با دیتابیس و API سروکار داشته باشم.
ولی چیزی که واقعاً یاد گرفتم، تفکر سیستمی بود.
حالا وقتی کد فرانت‌اند می‌نویسم، بهتر می‌فهمم درخواست‌ها از کجا میان، چرا باید بهینه باشن، و چطور یه تصمیم ساده توی UI می‌تونه روی Performance سرور تأثیر بذاره.
یادگیری بک‌اند برای من فقط یه مهارت جدید نبود؛ یه زاویه دید تازه بود به دنیای برنامه‌نویسی.

Kamyar Kamazani
👍3
🤣8👍1
ایلان ماسک بزودی پیام رسان X chat رو منتشر میکنه و در آینده ممکنه یک رقیب جدی برای تلگرام باشه
🤣2👍1
اگه از Toastها برای نمایش پیام‌ها استفاده می‌کنی و دنبال یه ابزار سبک، خوش‌استایل و راحتی، react-hot-toast یکی از بهترین انتخاب‌هاست.

طراحی مینیمال و جذابی داره. قابل شخصی‌سازی هست. وابستگی‌های سنگین هم نداره. از همه مهم‌تر JSX Content هم پشتیبانی می‌کنه.

https://react-hot-toast.com/
👍3
‏نظر نامحبوب:
‏تو مصاحبه های کاری متاسفانه تو اکثر موارد شما باید بازیگر و دروغ گوی خوبی باشین وگرنه ریجکت میشین. اگه همیشه بخواین صادق باشین جواب نمیده اونم تو دنیای فعلی و باید تا حدی اغراق کنین.
👍10
ا framer-motion چیست؟

کتابخانه‌ای برای ساخت انیمیشن در React که هم ساده‌ست، هم دقیق.
در واقع، framer-motion جایگزین قدرتمندیه برای CSS animation و transition،
با این تفاوت که کنترل کاملی روی state و eventهای React داریم.

https://motion.dev/