Code Module | کد ماژول
前往频道在 Telegram
Hello World 🌎 <> Earth is programmable if you code it Group 👇🏻 @CodeModuleGap Contact Us 👇🏻 @MrShahiin @neoMahan
显示更多1 962
订阅者
+424 小时
+147 天
+7830 天
帖子存档
ویدیو مد نظرتو با هوش مصنوعی ترجمه کن! 😎
توی این پست میخوام با ابزاری به اسم synclabs آشناتون کنم که به شما اجازه میده، تا هر ویدیو ای که دوست داشتید رو از هر جایی (یوتیوب، مقالات، وبلاگ ها و ...) رو به هر زبانی که میخواید ترجمه کنید.
دیگه نیاز نیست بخاطر بلد نبودن زبان های خارجه، منابعتون رو محدود کنید 🏖️
🔵Website
#ai #tools
@CodeModule
تا حالا اسم فریمورک Gatsby به گوشتون خورده؟ 🤔
در واقع Gatsby یک فریمورک منبع باز برای توسعه وبسایتهای استاتیکه که بر پایه React و GraphQL ساخته شده. این ابزار برای ساخت سایت هایی با صفحه های استاتیک، به خاطر سرعت لود بالاش فوق العادست.
برخی از ویژگی های Gatsby ⬇️
🔵پشتیبانی از Gatsby :GraphQL از GraphQL برای مدیریت دادهها استفاده میکنه که به دولوپرا این اجازه رو میده، تا دادهها رو به طور مستقیم از منابع مختلف (مانند CMS ها، فایلهای Markdown، API ها و غیره) فراخوانی کنن.
🔵پشتیبانی از پلاگینها: Gatsby دارای اکوسیستم وسیعی از پلاگینهاست که میتونن برای افزودن قابلیتهای مختلف مانند SEO، تصاویر بهینهسازی شده، آنالیتیکس و موارد دیگر استفاده بشن.
🔵مستندات قوی و جامعه فعال: Gatsby دارای مستندات جامع و کامیونیتی فعاله که به دولوپرا کمک میکنه، تا به سرعت یاد بگیرند و مشکلات خودشون رو حل کنن.
🔵پشتیبانی از Gatsby :PWA به دولوپرا این امکان رو میده تا به راحتی وبسایتهای خودشون رو به PWA تبدیل کنن، که باعث افزایش قابلیتهای آفلاین و تجربه کاربری بهتر میشه.
🔵بهینهسازی عملکرد: Gatsby به طور پیشفرض تکنیکهای مختلف بهینهسازی عملکرد، از جمله تقسیم کد (Code Splitting)، فشردهسازی تصویر (Image Optimization) و لود تنبل (Lazy Loading) رو پیادهسازی میکنه.
به طور خلاصه، Gatsby یک فریمورک قوی و منعطف برای توسعه وبسایتهای سریع، امن، و بهینه هست که با استفاده از React و GraphQL، تجربه دولوپرا و کاربران رو بهبود میبخشه. برای اطلاعات بیشتر میتونید به داکیومنت این فریمورک مراجعه کنید.
Document 🌐
#gatsby #react
@CodeModule
Good Night 🌚✨
كسى كه از اشتباهاتش درس نميگيره، مجبوره دوباره اونها رو زندگى كنه.
@CodeModule
🪴دائم برای نوشتن کامندای تکراری لینوکسی، وقت تلف میکنی ؟
توی این پست با هم یک راهکار یاد میگیریم که توی سیستم عامل لینوکس، به جای اینکه هی یک دستور تکراری و طولانی رو بارها و بارها بنویسیم و وقتمون رو تلف کنیم، براش یک alias بنویسیم تا با کامند کوتاه و دلخواهمون اون دستور رو اجرا کنیم 🥹
داخل سیستم عامل های لینوکسی یک فایل وجود داره به اسم bashrc، که داخل این فایل ما میتونیم یسری کانفیگ برای shell بنویسیم، مثل فانکشن های کاستوم شده و یا alias ها و ... که بتونیم، اونارو داخل shell اجرا کنیم.
🔵برای تعریف دستور های دلخواهمون با استفاده از alias در فایل bashrc، ابتدا کافیه با ادیتوری که روی سیستم عاملتون دارید فایل رو باز کنید (من با nano این کارو انجام میدم) :
# syntax :
# nano <.bashrc dir>
nano ~/.bachrc
🔵مرحله بعد در فایل باز شده کمی که به سمت پایین اسکرول کنید، چند تا alias دیفالت کامنت شده که میتونید، پایینشون alias خودتون رو تعریف کنید.
برای تعریف alias باید از خود کلمه کلیدی alias استفاده کنید و اسم شناسه دلخواهتون رو بنویسید، و برای مقدار هم کامند مورد نظر رو قرار بدید، طبق سینتکس زیر (برای مثال من کامند shutdown رو تست میکنم) :
# alias syntax :
# alias <keyword>='<command>'
alias shut='sudo shutdown -P now'
بعد از اینکه alias هاتون رو تعریف کردید، فایل رو سیو میکنید و خارج میشید. حالا اگه دستورتون رو در shell وارد کنید کامند رو پیدا نمیکنه، چون برای اینکه بتونید shell configuration government رو آپدیت کنید تا alias ها یا سایر کانفیگ ها قابل استفاده بشن، باید دستور زیر رو وارد کنید:
# syntax :
# source <.bashrc dir>
source ~/.bashrc
🔵الان دیگه با زدن کامند shut در shell، خودش دستور sudo shutdown -P now رو برامون اجرا میکنه و دیگه نیازی نیست هر دفعه تایپش کنیم و وقتمون گرفته بشه. شما هم میتونید کامند های پرکاربرد لینوکسی تون رو با این روش، کوتاه تر و سریع تر بنویسید 🧑🎓
#linux #shell
@CodeModuleمتغیر محیطی چیه و کاربردش در Node.js 🤟
متغیرهای محیطی (Environment Variables) مقادیر پویایی با نامهای مشخص هستن، که در خارج از برنامه تنظیم میشن و به طور کلی برای پیکربندی برنامه در محیطهای مختلف (مانند توسعه، تولید و تست) یا ذخیره اطلاعات حساس که نباید به صورت پابلیک در کد ذخیره بشن، استفاده میشه.
نحوه تنظیم متغیرهای محیطی ⬇️
روشهای مختلفی برای تنظیم متغیرهای محیطی در Node.js وجود داره.
🔵 تنظیم از طریق ترمینال :
export NODE_ENV=production
node app.js
🔵 تنظیم در فایل.env:
ابتدا یک فایل .env در پروژه میسازیم و متغیرهای محیطی رو به صورت KEY=VALUE تعریف میکنیم:
NODE_ENV=production
DB_HOST=localhost
DB_PASSWORD=secret123
و بعد میتونیم با استفاده از پکیجی مثل dotenv این فایل رو در برنامه خودمون بارگیری کنیم:
const dotenv = require('dotenv');
dotenv.config();
console.log(process.env.NODE_ENV); // Output: production
دسترسی به متغیرهای محیطی در Node.js
در nodejs ما با استفاده از process.env که به صورت سراسری یا گلوبال در دسترس هست، میتونیم به متغیر های محیطی دسترسی داشته باشیم، و برای نام گذاری متغیر های محیطی باید نام متغیرها رو با حروف بزرگ و با underscore جدا کنیم. ( چون این یک قانون و استاندارده)
const hostname = process.env.DB_HOST;
console.log(hostname); // Output: localhost
🔵 از متغير های محیطی برای تنظیم مقادیر مختلف مانند آدرس سرور دیتابیس، پورت برنامه، و اطلاعات حساس مثل رمز عبور دیتابیس و غیره استفاده میشه. در حالت معمولی، نباید این اطلاعات رو در کد ها ذخیره کنیم.
🔵 برای راحتی و دسترسی مطمئن تر به متغیر های محیطی، میتونیم از پکیج dotenv استفاده کنیم.
به صورت کلی با استفاده از متغیر های محیطی، میتونیم کد های nodejs خودمون رو تمیز تر و امن تر نگه داریم.
#env #environment_variables
@CodeModule🔵 با تابع calc در Css بیشتر آشنا بشید!
تابع ()calc برای انجام عملیات ریاضی ساده و پیشرفته، روی ابعاد و ویژگیهای یک واحد طراحی وب استفاده میشه. این تابع به طراحان وب امکان میده تا مقادیر پیکسلی، درصدی و دیگر واحدهای مورد استفاده در CSS رو با بقیه ترکیب کنن و به شکل دقیقتر کنترل کنن.
این تابع بخصوص برای انجام عملیات ریاضی بر روی مقادیر نسبی (مثل em, rem, vw, %) بسیار کاربردی و مفیده. در مثال زیر عرض یک عنصر نسبت به عرض عنصر نگهدارنده اون (والدش) محاسبه شده :
.element {
margin-right: calc(10% + 5px);
}
⚠️ توجه داشته باشید که باید بین علامت ریاضی، جمع و تفریق و مقادیر، یک فاصله وجود داشته باشه، در غیر این صورت استایل درست محاسبه نمیشه و با مشکل رو به رو میشیم.
اما برای ضرب و تقسیم اگر فاصله وجود نداشته باشه، مشکلی به وجود نمیاد و محاسبه به درستی انجام میشه.
margin-right: calc(10% -5px); /* خطا */
margin-right: calc(10% +5px); /* خطا */
margin-right: calc(10%/5px); /* صحیح */
margin-right: calc(10%*5px); /* صحیح */
با استفاده از این تابع، میتونید دقیق تر و حساب شده تر مقادیر پراپرتی هاتون رو حساب کنید. نمونه مثال بیشتر و سایر اطلاعات رو میتونید تو مقاله زیر مطالعه کنید 🏖️
🔵Article
#css #calc
@CodeModule۵ پستی که پیشنهاد میکنم از دست ندید (پارت دوم) 💀
🔵اهمیت مهارت سرچ در برنامه نویسی
🔵اصول نوشتن کامیت حرفهای در گیتهاب
🔵تبدیل ui سایت مد نظر به فایل فیگما
🔵مفهوم TDD در برنامه نویسی
🔵۵ نکته جهت نوشتن کد تمیز و خوانا
🔴پارت قبل رو یادتون نره :))
#top
@CodeModule
همه چیز راجب Container ها ⚡️
امروزه در دنیای نرم افزار، Container ها نقش مهمی پیدا کردن و داخل تکنولوژی های بزرگی مثل Docker و kubernetes که دربارشون مفصل صحبت کردیم، استفاده میشن.
🗂 اما کانتینرها دقیقا چی هستند؟
در واقع Containerization یک روش استقرار نرم افزاره که کد برنامه رو با تمام وابستگی های اون (کتابخانه ها و فایل های کانفیگ) مورد نیاز برای اجرا، در یک واحد مستقل به اسم Container بسته بندی میکنه. پس کانتینرها محل نگهداری دپندنسیها و کانفیگیوریشن فایلها هستن.
🤔 کانتینرها چجوری کار میکنن؟
1️⃣مرحله اول : ساخت تصویر
ما به عنوان یک دولوپر کد هارو مینویسیم و تمام وابستگی های مورد نیاز رو مشخص میکنیم. با استفاده از ابزار هایی مثل Docker یک تصویر درست میکنیم که این تصویر شامل تمام چیز هایی هست که برای اجرای برنامه در هر محیطی نیازه، که از استاندارد (OCI) Open Container Initiative پیروی میکنه.
💙 این تصویر از چند لایه تشکیل میشه:
◀️لایه پایه : معمولا شامل یک سیستم عامل مینیمال مثل لینوکس هست.
◀️لایه های وابستگی : این لایه حاوی کتابخونه های از پیش نصب شده و اجزای مورد نیاز برنامه هست.
◀️لایه برنامه : حاوی کد های برنامه و هر فایل پیکربندی اضافه مخصوص برنامه هست.
2️⃣مرحله دوم : اجرای کانتینر
زمانی که یک تصویر رو با استفاده از موتور Docker اجرا میکنید، یک کانتینر در حال اجرا از اون تصویر ایجاد میشه.
موتور Docker از هسته سیستم عامل میزبان برای عملکردهای اصلی استفاده میکنه، اما فرایندها و منابع کانتینر رو ایزوله میکنه.
این امر باعث میشه یک محیط اجرای سبک و کارآمد برای اجرای برنامه فراهم میشه.
⚠️ نکات مهمی که بهتره بدونید:
🔵 هر کانتینر در یک فضای کاربری جداگانه اجرا میشه که از تداخل بین برنامهها یا وابستگیها جلوگیری میکنه.
🔵 برای مدیریت تعداد زیادی از کانتینرها، از پلتفرمهای ارکستراسیون کانتینری مثل Kubernetes استفاده میشه.
🔵 بسیاری از پلتفرمهای کانتینری مثل Docker، از رویکرد "امن به صورت پیشفرض" پشتیبانی میکنن، به این معنا که ویژگیهای امنیتی به طور پیشفرض فعال هستن و خطر پیکربندی نادرست رو کاهش میدن.
اما یکسری نقاط ضعف هم وجود داره :
🔢 برخی از منابع هسته سیستم عامل اصلی یا فریمورک های مشترک ممکن توسط چند کانتینر قابل دسترسی باشن، این میتونه آسیب پذیری احتمالی در صورت عدم مدیریت رو ایجاد کنه.
🔢 یک نقض امنیتی در سیستم عامل میزبان میتونه همه کانتینر های درحال اجرا رو به خطر بندازه.
به صورت کلی اگر به دنبال افزایش کارایی، مقیاس پذیری و امنیت در پروژه ها هستید، بهتره از داکر و کانتینرها استفاده کنید🔥
#docker #containerization #container #kubernetes
@CodeModule
🎨 با مجموعه Shadcn بیشتر آشنا بشید !
در واقع Shadcn یک مجموعه ابزار برای ساخت رابطهای کاربری (UI) هست که پرقدرت و نسبتا نوظهوره، و با ارائه کامپوننتها و ابزارهای مدرن، دولوپرا و توسعهدهنده هارو با تجربهای بینظیر آشنا میکنه. این کتابخانه در واقع مجموعه ای از کامپوننت های reusable هست که با Radix و Tailwind ساخته شده.
این ابزار با تمرکز بر سادگی و انعطاف پذیری، کامپوننت های گستردهای برای طراحی وبسایتها و پروژه ها ارائه میده.
✅ مزایای استفاده از Shadcn چیه :
✅ طراحی زیبا و حرفهای کامپوننت ها
✅ قابلیت کاستوم سازی کامپوننت ها
✅ سریع و بهینه
✅ یادگیری و استفاده آسان
✅ مزایای Shadcn در برابر رقبا چیه ؟
مزایای Shadcn نسبت به سایر رقبا از جمله Bootstrap و Materialize، سبکی، سرعت، انعطاف پذیری و ... هست. همچنین، بهبود پایداری و امنیتی و ایجاد قابلیتهای مدرن، این ابزار رو از سایرین رقباش متمایز میکنه.
🔵 یکی دیگه از ویژگی بسیار جذاب این کتابخانه، اینه که شما میتونین کامپوننت ها رو به صورت جداگانه و به راحتی نصب کنید.
در کل Shadcn UI ابزار یا کتابخانه ای هست که دولوپرا رو در ساخت رابطهای کاربری زیبا، کارآمد و یکپارچه یاری میکنه. با استفاده از Shadcn میتونیم فرآیند توسعه رو سریع تر، کیفیت و یکنواختی UI رو افزایش و تجربه کاربری بهتری ارائه بدیم.
برای یادگیری و اطلاعات بیشتر راجب این کتابخانه، میتونید به داکیومنتش مراجعه کنید 🏖️
Document 🌕
#ui #shadcn
@CodeModule
Good Night 🌑✨
اگه میخوای پرواز کنی؛ باید همه بار های سنگینی که تو رو به سمت پایین میکشن؛ رها کنی.
@CodeModule
بافر چیه و چه کاربردی در Node.js داره؟🚀
تا الان حتما اسم بافر رو شنیدید و شاید در مرحله اول، کمی براتون گُنگ به نظر رسیده باشه. تو این پست به بررسی تخصصی بافر میپردازیم، پس با ما همراه باشید.
قبل از بررسی بافر، باید راجب بایت و بیت اطلاعاتی داشته باشیم.
بیت: ابتدایی ترین سطح داده ها که به صورت 0 و 1 نمایش داده میشن.
بایت: مجموعهی هشت بیت متوالی بایت نامیده میشود، که ظاهرشون بهطور مثال 01010101 میباشد.
اما بافرها چی هستن؟ 🤔
بافرها نظارت کنندههای موقت بر دادهها هستند. آنها دادهها رو نگهداری و دسترسی بهشون رو فراهم میکنن، بدون اینکه به دادهها آسیبی وارد شود ( شبیه یک نگهبان)
یکی از مزیت های قابل توجه بافرها، اینه که هرگونه اختلاف جریان داده ها رو متعادل میکنه و باعث میشه فرایند های کند مانع فرایند های سریع تر نشود.
نحوه استفاده از بافرها در Node.js 🤟
در Node.js، از بافرها زمانی استفاده میکنیم که نیاز به کار با فایلهای باینری، جریانهای TCP و دسترسی سریع و مستقیم به دادههای بایتی داشته باشیم. همچنین برای کار با رشتههای باینری یا دادههای باینری هم، از بافرها در Node.js استفاده میشود.
برای درک بهتر موضوع، میتونیم به سناریو زیر اشاره کنیم⬇️
زمانی که میخوایم یک فیلم یا ویدیو رو از سرویس های آنلاین مثل یوتیوب مشاهده کنیم، حتما براتون سوال شده که چه جوری بدون اینکه کل فیلم دانلود بشه، میتونیم شروع به دیدن ویدیو کنیم. این وظیفه بافرها هست و به طور کلی به این صورته:
ابتدا داده های درحال دانلود در یک بافر ذخیره میشن و این بافر، مثل یک وسیله نگه دارنده عمل میکنه که به نوعی شبیه به یک اتاقه، و زمانی که داده ها به قدر کافی در بافر ذخیره شده باشه، ویدیو شروع به پخش میشه و در حین تماشا داده های بیشتری به بافر اضافه میشود. این فرایند امکان پخش محتوا رو بدون نیاز به انتظار برای دانلود کامل، محیا میکنه.
در نهایت میتونیم نتیجه بگیریم که بافرها در Node.js، نقش مهمی در کنترل و مدیریت دادههای باینری و بایتی دارن، و برای انجام عملیات مرتبط مانند آپلود فایل، خواندن دادهها و کلی کاربرد دیگه، قابل استفاده هستند.
#buffer #nodejs
@CodeModule
طرحهای فیگما واسه توسعه و کدنویسی (پارت اول)🎨
🔵طرح فیگما سایت املاکی (دارای تعداد صفحات بالا + رسپانسیو)
🔵طرح فیگما سایت پوشاکی (دارای تعداد صفحات بالا + رسپانسیو)
🔵طرح فیگما سایت آشپزی
🔵طرح فیگما سایت شخصی
🔵طرح فیگما سایت موسیقی (سلیقه ادمین)
#figma
@CodeModule
🤟 سوالات مصاحبه ای Node.js
🟢در این پست، چند منبع برای سوالات مصاحبه ای Node.js به همراه پاسخ بهتون معرفی میکنم، که هم برای تقویت دانش و هم افزایش درصد موفقیت در مصاحبه ها، فوق العاده مفید و کاربردیه.
🐱 https://gist.github.com/paulfranco
🐱 https://github.com/Devinterview-io
🐱 https://github.com/Mohamed-Hashem
#nodejs #interview
@CodeModule
现已上线!2025 年 Telegram 研究 — 年度关键洞察 
