اتاق برنامه نویسی </>
405 subscribers
63 photos
1 video
7 links
📌 کانال آموزش لاراول
@PapiDon_state
Download Telegram
اتاق برنامه نویسی </>
Photo
میکرو فرانت‌اند (Micro Frontend) چیست؟

میکرو فرانت‌اند، رویکردی نوین در توسعه وب است که از اصول معماری میکروسرویس‌ها در بخش فرانت‌اند وب‌سایت‌ها استفاده می‌کند. این رویکرد به تیم‌های توسعه اجازه می‌دهد تا قسمت‌های مختلف واسط کاربری (UI) یک وب‌سایت بزرگ را به صورت جداگانه و مستقل توسعه دهند، طراحی کنند و مدیریت نمایند.

🧩 کاربرد و فواید میکرو فرانت‌اند

🔸تقسیم کار و تخصصی‌سازی: هر تیم می‌تواند روی بخش خاصی از UI تمرکز کرده و تخصص خود را در آن زمینه اعمال کند.

🔸استقلال و انعطاف‌پذیری: تیم‌ها می‌توانند در انتخاب فناوری‌ها و ابزارهای خود مستقل باشند.

🔸تسهیل مدیریت پروژه: کاهش وابستگی‌های میان تیم‌ها به مدیریت راحت‌تر پروژه‌های بزرگ کمک می‌کند.

🛠 چالش‌های میکرو فرانت‌اند

🔹هماهنگی و ارتباط: نیاز به هماهنگی دقیق بین تیم‌های مختلف برای اطمینان از یکپارچگی کلی سیستم.

🔹پیچیدگی فنی: مدیریت وابستگی‌ها و ارتباطات بین بخش‌های مختلف می‌تواند پیچیده باشد.

🔹عملکرد: اطمینان از عملکرد بالا و سازگاری در تمام بخش‌ها چالش برانگیز است.

🔄 چگونگی پیاده‌سازی

پیاده‌سازی میکرو فرانت‌اند به طراحی دقیق و در نظر گرفتن جنبه‌هایی نظیر مدیریت وابستگی‌ها، روش‌های ارتباطی بین کامپوننت‌ها و استراتژی‌های اعمال تغییرات نیاز دارد. ابزارهایی مانند Webpack, Module Federation و فریم‌ورک‌های مدرن مانند React یا Angular می‌توانند در این زمینه کمک کننده باشند.

🏛 معماری مونولیتیک (Monolith) چیست؟

در معماری مونولیتیک، کل وب‌سایت یا اپلیکیشن به صورت یکپارچه و در هم تنیده طراحی و توسعه می‌یابد. در این سیستم، فرانت‌اند و بک‌اند به شدت به هم وابسته‌اند و هر تغییری نیاز به بازبینی و تست کل سیستم دارد.

🔄 تفاوت‌های میکرو فرانت‌اند و معماری مونولیتیک

- تجزیه و تحلیل: میکرو فرانت‌اند به تقسیم بخش‌های مختلف UI و مدیریت مستقل آن‌ها توسط تیم‌های مختلف می‌پردازد، در حالی که در معماری مونولیتیک، تمام اجزای سیستم به صورت یکپارچه توسعه می‌یابند.

- انعطاف‌پذیری: میکرو فرانت‌اند به تیم‌ها اجازه می‌دهد تا در انتخاب فناوری‌ها و روش‌های کار خود مستقل باشند، در حالی که در معماری مونولیتیک، تیم‌ها محدود به استفاده از فناوری‌ها و استانداردهای مشترک هستند.

- مقیاس‌پذیری و نگهداری: میکرو فرانت‌اند امکان مقیاس‌پذیری و توسعه مستقل بخش‌های مختلف را فراهم می‌کند، در حالی که در مونولیتیک، تغییرات و نگهداری می‌تواند دشوارتر باشد زیرا هر تغییری ممکن است بر کل سیستم تأثیر بگذارد.

- زمان توسعه و راه‌اندازی: در میکرو فرانت‌اند، توسعه و راه‌اندازی سریع‌تر است زیرا تیم‌ها می‌توانند بخش‌های مختلف را به صورت مستقل کار کنند. در مونولیتیک، همه چیز باید به صورت همزمان توسعه یابد و تست شود.

📝 نتیجه‌گیری

میکرو فرانت‌اند با ارائه رویکردی ماژولار و انعطاف‌پذیر، به تیم‌های توسعه اجازه می‌دهد تا به صورت مستقل و کارآمدتر بر روی بخش‌های مختلف یک پروژه وب کار کنند. این در حالی است که معماری مونولیتیک، به دلیل وابستگی‌های درونی و یکپارچگی بالا، محدودیت‌ها و چالش‌های خاص خود را دارد.



📁 #MicroFrontend

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
👍21🔥1🙏1
اتاق برنامه نویسی </>
Photo
🌐 PostgreSQL

یک سیستم مدیریت پایگاه داده‌های رابطه‌ای متن‌باز (RDBMS) است که برای انعطاف‌پذیری، پایداری و قابلیت‌های پیشرفته شناخته می‌شود. رایگان است و قابلیت‌های پیشرفته‌ای مانند پشتیبانی از تراکنش‌های پیچیده، JOIN‌های پیشرفته، ویوها (Views)، و توابع ذخیره‌شده (Stored Procedures) را ارائه می‌دهد.

مزایای PostgreSQL نسبت به MySQL:

1️⃣ توسعه‌پذیری بالا: PostgreSQL برای پشتیبانی از پردازش‌های بزرگ داده‌ای و عملیات پیچیده بهینه‌سازی شده است.

2️⃣ پشتیبانی از داده‌های مکانی: PostgreSQL با افزونه PostGIS، پشتیبانی قدرتمندی برای داده‌های مکانی ارائه می‌دهد.

3️⃣ امنیت بالا: ارائه امکانات امنیتی پیشرفته، از جمله کنترل دسترسی دقیق و رمزنگاری داده‌ها.

4️⃣ پشتیبانی از "NoSQL": قابلیت‌های NoSQL مانند JSON و XML را پشتیبانی می‌کند.

5️⃣ قابلیت انعطاف‌پذیری: PostgreSQL به دلیل معماری پیشرفته‌تر خود، انعطاف‌پذیری بیشتری در مدیریت پایگاه داده‌ها و طراحی دارد.

🆚 MySQL || PostgreSQL:

درواقع MySQL نیز یک سیستم مدیریت پایگاه داده محبوب است که بیشتر برای کاربردهای وب و کاربردهای کوچکتر مناسب است. در حالی که MySQL برای سادگی و سرعت شناخته شده، PostgreSQL برای قابلیت‌های پیشرفته‌تر و انعطاف‌پذیری بیشتر در برخورد با داده‌های پیچیده و بزرگ مورد توجه قرار می‌گیرد.

🔥چرا PostgreSQL را انتخاب کنیم؟

اگر نیاز به پایگاه داده‌ای دارید که از عملیات پیچیده و بزرگ داده‌ای پشتیبانی کند، PostgreSQL گزینه‌ای عالی است. همچنین، اگر به دنبال امنیت بالا و انعطاف‌پذیری در تعریف داده‌ها هستید، PostgreSQL می‌تواند نیازهای شما را برآورده سازد.

نتیجه‌گیری:

در حالی که MySQL برای پروژه‌های کوچکتر و ساده‌تر مناسب است، PostgreSQL برای پروژه‌های بزرگتر و پیچیده‌تر که نیاز به قابلیت‌های پیشرفته‌تر دارند، یک انتخاب عالی است.



📁 #PostgreSQL

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
👍21
تفاوت‌های اصلی بین ORM و ODM

🌐 در دنیای برنامه‌نویسی، دو ابزار کلیدی برای تعامل با پایگاه‌های داده وجود دارد: ORM و ODM. بیایید نگاهی دقیق‌تر به تفاوت‌های این دو بیندازیم:

🔹مفهوم ORM (Object-Relational Mapping):

- کاربرد: به کار رفتن در پایگاه‌داده‌های رابطه‌ای مانند MySQL, PostgreSQL, و SQLite.

- عملکرد: تبدیل جداول پایگاه داده به اشیاء در زبان برنامه‌نویسی. هر جدول معادل یک کلاس و هر رکورد معادل یک نمونه از آن کلاس می‌باشد.

- مزایا: امکان تعامل آسان با پایگاه‌داده‌های رابطه‌ای بدون نیاز به نوشتن کوئریهای پیچیده SQL.

🔸مفهوم ODM (Object-Document Mapping) :

- کاربرد: استفاده برای پایگاه‌داده‌های مدارک مانند MongoDB.

- عملکرد: تبدیل اسناد پایگاه داده به اشیاء در زبان برنامه‌نویسی. هر سند می‌تواند ساختار داده‌ای پیچیده‌ای داشته باشد.

- مزایا: امکان تعامل راحت با پایگاه‌داده‌های مبتنی بر (Document-based) و بهره‌گیری از انعطاف‌پذیری و ساختار چندگانه‌ی داده‌ای آن‌ها




📁 #ORM #ODM

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
👍61
اتاق برنامه نویسی </>
Photo
💻 راهنمای نصب لینوکس در ویندوز با استفاده از WSL (Windows Subsystem for Linux)

🎯 این راهنما به شما کمک می‌کند تا به راحتی یک توزیع لینوکس را در محیط ویندوز خود با استفاده از Windows Subsystem for Linux (WSL) نصب کنید - بدون نیاز به استفاده از ماشین‌های مجازی سنگین!

🛠 مرحله 1: فعال‌سازی WSL در ویندوز

1️⃣ باز کردن PowerShell به عنوان مدیر (Administrator)

- روی دکمه استارت راست‌کلیک کنید و Windows PowerShell (Admin) را انتخاب کنید.

2️⃣ اجرای دستور زیر برای فعال‌سازی WSL


wsl --install


- این دستور، WSL را به همراه توزیع پیش‌فرض Ubuntu نصب می‌کند.

3️⃣ ریستارت کامپیوتر

- پس از اتمام نصب، سیستم خود را ریستارت کنید.


🐧 مرحله 2: بررسی و انتخاب توزیع لینوکس

4️⃣ بررسی توزیع‌های موجود

- پس از ریستارت، PowerShell را باز کرده و دستور زیر را اجرا کنید:

     
wsl --list --online


- لیست توزیع‌های قابل نصب نمایش داده می‌شود.

5️⃣ انتخاب و نصب توزیع دلخواه

- برای نصب توزیع مورد نظر، مثلاً Ubuntu، دستور زیر را وارد کنید:


wsl --install -d Ubuntu


🔑 مرحله 3: تنظیم حساب کاربری لینوکس

6️⃣ ایجاد نام کاربری و رمز عبور

- پس از نصب توزیع، یک پنجره ترمینال باز می‌شود که از شما می‌خواهد نام کاربری و رمز عبور ایجاد کنید.

- نام کاربری را وارد کنید (مثلا ali).
- رمز عبور را ایجاد کرده و تأیید کنید.


⚙️ مرحله 4: شروع به کار با لینوکس

7️⃣ استفاده از توزیع لینوکس

- پس از اتمام تنظیمات، شما می‌توانید از توزیع لینوکس خود در محیط WSL استفاده کنید.

- دستورات لینوکس را می‌توانید مستقیماً در این ترمینال اجرا کنید.


🎉 تبریک! شما با موفقیت یک توزیع لینوکس را در ویندوز خود نصب کردید. حالا می‌توانید از امکانات و قابلیت‌های لینوکس در محیط ویندوز بهره‌مند شوید!




📁 #Linux #Windows

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
👍5🔥1
اتاق برنامه نویسی </>
Photo
تفاوت بین استفاده از Windows Subsystem for Linux (WSL) و ماشین‌های مجازی (VMs) برای اجرای لینوکس در ویندوز در چند جنبه اصلی خلاصه می‌شود:

1️⃣ 🏃 عملکرد و کارایی

🔸 WSL:

- ارائه عملکرد بالاتر و استفاده بهینه‌تر از منابع سیستم، زیرا WSL مستقیماً روی سیستم عامل میزبان اجرا می‌شود و نیازی به شبیه‌سازی کل سخت‌افزار ندارد.
- واکنش سریع‌تر و زمان بارگذاری کمتر نسبت به ماشین‌های مجازی.

🔹ماشین‌های مجازی:

- ممکن است کمی کندتر از WSL باشند چون نیاز به شبیه‌سازی یک سیستم کامل سخت‌افزاری دارند.
- استفاده بیشتر از منابع سیستم، مخصوصاً در زمینه حافظه و پردازنده.

2️⃣ 📦 مدیریت منابع

🔸 WSL:

- به طور خودکار منابع سیستم را مدیریت می‌کند و به اندازه نیاز منابع را تخصیص می‌دهد.
- اشغال فضای کمتر در هارد دیسک نسبت به یک VM کامل.

🔹ماشین‌های مجازی:

- نیاز به تخصیص دستی منابع دارند، مانند تعیین مقدار حافظه RAM و فضای دیسک.
- ممکن است فضای بیشتری را در هارد اشغال کنند.

3️⃣ ⚙️ تعامل با سیستم عامل میزبان

🔸 WSL:

- امکان دسترسی و تعامل آسان با فایل‌های ویندوز.
- اجرای برنامه‌های ویندوز و لینوکس به طور هم‌زمان و بدون مشکل.

🔹ماشین‌های مجازی:

- محیط کاملاً جدا از سیستم عامل میزبان.
- نیاز به راه‌اندازی سیستم‌های فایل مجزا و انتقال فایل بین میزبان و مهمان.

4️⃣ 🔧 راه‌اندازی و نگهداری

🔸 WSL:

- راه‌اندازی سریع و ساده‌تر.
- نیاز به نگهداری کمتر و به‌روزرسانی‌های ساده‌تر از طریق ویندوز.

🔹ماشین‌های مجازی:

- راه‌اندازی اولیه ممکن است پیچیده‌تر و زمان‌بر باشد.
- نیاز به نگهداری دوره‌ای مانند به‌روزرسانی‌های سیستم عامل مهمان.

5️⃣ 🔄 انعطاف‌پذیری

🔸 WSL:

- محدود به توزیع‌های لینوکسی که توسط مایکروسافت پشتیبانی می‌شوند.

🔹ماشین‌های مجازی:

- امکان نصب و اجرای طیف وسیع‌تری از سیستم‌های عامل، از جمله نسخه‌های مختلف لینوکس و حتی سیستم‌های عامل دیگر.


💠 در نهایت، انتخاب بین WSL و ماشین مجازی به نیازهای خاص کاربر و سناریوهای استفاده بستگی دارد. WSL برای توسعه‌دهندگانی که به دنبال یک محیط سبک‌تر و تعامل نزدیک‌تر با ویندوز هستند، مناسب است، در حالی که ماشین‌های مجازی برای مواردی که نیاز به جداسازی کامل و پشتیبانی از سیستم‌های عامل متنوع است، ایده‌آل هستند.



📁 #Linux #Windows

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
👍41🔥1
اتاق برنامه نویسی </>
Photo
⚙️ اینترنت اشیاء (IoT) به مفهوم گسترده‌تر و پیشرفته‌تر اتصال دستگاه‌ها و وسایل مختلف به اینترنت اشاره دارد، که فراتر از محدوده سنتی ارتباطات الکترونیکی است. در این سیستم، اشیاء یا دستگاه‌هایی که پیشتر هیچ‌گونه قابلیت ارتباطی نداشتند، توانایی جمع‌آوری، ارسال و دریافت اطلاعات را دارند. این دامنه شامل وسایل خانگی معمولی مانند یخچال‌ها و تلویزیون‌ها، و همچنین وسایل پیچیده‌تر مانند خودروها، سیستم‌های حمل‌ونقل شهری و تجهیزات پزشکی می‌شود.

این تکنولوژی، امکان ارتباط بین دستگاه‌ها و تبادل اطلاعات را فراهم می‌آورد که منجر به خلق سیستم‌های هوشمند و خودکار می‌شود. مثلاً، یک یخچال هوشمند می‌تواند محتویات خود را تحلیل کرده و در صورت نیاز، به صورت خودکار سفارش مواد غذایی دهد. یا سیستم روشنایی هوشمند که بر اساس حضور افراد در اتاق، شدت نور را تنظیم می‌کند.

🌍 در زمینه‌های مختلفی چون صنعت، کشاورزی، حمل‌ونقل و بهداشت و درمان، IoT کاربردهای گسترده‌ای دارد. از طریق IoT، جمع‌آوری اطلاعات دقیق و لحظه‌ای میسر می‌شود که به بهینه‌سازی فرآیندها کمک می‌کند. به عنوان نمونه، در بخش کشاورزی، سیستم‌های IoT می‌توانند شرایط محیطی مانند رطوبت، دما و سطح مواد مغذی خاک را کنترل کرده و به کشاورزان در مدیریت موثرتر مزارع یاری رسانند.

🔒 در حالی که IoT فرصت‌های بی‌شماری را فراهم می‌آورد، چالش‌هایی مانند امنیت سایبری و حفظ حریم خصوصی نیز مطرح است که نیازمند توجه دقیق و اتخاذ راهکارهای مناسب است. این مسئله تأکید می‌کند بر اهمیت طراحی سیستم‌های IoT با در نظر گرفتن اصول امنیتی و حفاظت از داده‌های شخصی کاربران.




📁 #IoT

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
👍4🔥1
اتاق برنامه نویسی </>
Photo
JS Design Patterns: A Comprehensive Guid

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

1️⃣ الگو Singleton Pattern:

این الگو اطمینان می‌دهد که یک کلاس تنها یک نمونه (instance) داشته باشد. مثلاً برای مدیریت پایگاه‌داده یا تنظیمات سیستمی در جاوا اسکریپت کاربرد دارد. کد نمونه زیر نشان‌دهنده این است که چگونه دو شیء از یک کلاس به یک نمونه اشاره می‌کنند:


   let instance;
class Database {
constructor(data) {
if (instance) {
return instance;
}
this.data = data;
instance = this;
}
getData() {
return this.data;
}
}
const db1 = new Database('db1');
const db2 = new Database('db2');
console.log(db1 === db2); // true


2️⃣ الگو Observer Pattern:

این الگو به شما اجازه می‌دهد تغییرات در یک شیء را رصد کنید و در صورت وقوع تغییرات، اطلاع‌رسانی کنید. این کد نشان می‌دهد چگونه می‌توانید اشیاء را به یک موضوع مشترک متصل کنید و در هنگام تغییر داده‌ها، اطلاع‌رسانی کنید:


   class Subject {
constructor() {
this.observers = [];
}
subscribe(observer) {
this.observers.push(observer);
}
unsubscribe(observer) {
this.observers = this.observers.filter(obs => obs !== observer);
}
notify(data) {
this.observers.forEach(observer => observer.update(data));
}
}
class Observer {
update(data) {
console.log(`Observer received data: ${data}`);
}
}
const subject = new Subject();
const observer1 = new Observer();
const observer2 = new Observer();
subject.subscribe(observer1);
subject.subscribe(observer2);
subject.notify('Hello World');


3️⃣ الگو Module Pattern:

این الگو به شما کمک می‌کند تا کد خود را به صورت ماژول‌های مستقل سازمان‌دهی کنید تا از تداخل متغیرها و توابع در فضای نام جلوگیری شود:


   const MyModule = (() => {
let privateVar = 'I am private';
return {
publicMethod: () => `The value of privateVar is: ${privateVar}`
};
})();
console.log(MyModule.publicMethod());





📁 #javascript #DesignPatterns

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
10
اتاق برنامه نویسی </>
Photo
هدف‌گذاری SMART یکی از روش‌های مؤثر در تعیین اهداف و برنامه‌ریزی برای دستیابی به آنها است. این روش بر پنج اصل اساسی استوار است:

🔸 SMART 🔸

1. 🎯 Specific (مشخص)

اهداف باید روشن و دقیق باشند. به جای هدف‌های کلی و مبهم، هدف باید به شکلی مشخص و واضح تعریف شود. مثلاً به جای «من می‌خواهم در کارم بهتر شوم»، می‌توان گفت «من می‌خواهم در طول شش ماه آینده در زمینه برنامه‌نویسی جاوا مهارت پیدا کنم».

2. 📏 Measurable (قابل اندازه‌گیری)

باید بتوان پیشرفت در راستای دستیابی به هدف را اندازه‌گیری کرد. برای مثال، «من می‌خواهم در هر ماه دو کتاب در زمینه توسعه نرم‌افزار بخوانم» یک هدف قابل اندازه‌گیری است.

3. 🏆 Achievable (قابل دستیابی)

اهداف باید واقع‌بینانه و قابل دستیابی باشند. اهداف بلندپروازانه خوب هستند، اما باید در حدود توان و منابع موجود قابل دستیابی باشند.

4. 🔗 Relevant (مرتبط)

اهداف باید با نیازها، خواسته‌ها و اهداف بلندمدت شما مرتبط باشند. مثلاً اگر هدف اصلی شما تبدیل شدن به یک توسعه‌دهنده نرم‌افزار است، یادگیری مهارت‌های مرتبط با برنامه‌نویسی مرتبط خواهد بود.

5. Timely (محدود در زمان)

برای هر هدف باید یک جدول زمانی مشخص وجود داشته باشد. تعیین مهلت کمک می‌کند تا بر روی اهداف تمرکز کرده و آنها را به موقع دنبال کنید.

🧩 اهمیت هدف‌گذاری SMART در زندگی حرفه‌ای و شخصی

استفاده از این روش به افراد و سازمان‌ها کمک می‌کند تا اهداف خود را به شیوه‌ای سازمان‌دهی شده و عملی پیگیری کنند، به گونه‌ای که امکان پیشرفت و موفقیت را افزایش دهد. این روش به ویژه در مدیریت پروژه‌ها، برنامه‌ریزی شخصی و توسعه حرفه‌ای کاربرد فراوانی دارد.

🔔 نکات مهم در هدف‌گذاری SMART

🔹اجتناب از تعیین اهداف غیر واقع‌بینانه که ممکن است منجر به ناامیدی شود.

🔹تطبیق اهداف با منابع و توانایی‌های موجود برای افزایش شانس موفقیت.

🔹انعطاف‌پذیری و تعدیل اهداف در صورت تغییر شرایط.



📁 #TimeManagement

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
👍61
اتاق برنامه نویسی </>
Photo
سه الگوریتم با جاوا اسکریپت

1️⃣ وارونه کردن یک رشته

این یکی از اولین چالش‌های الگوریتمی است که ممکن است با آن روبرو شوید. حل آن در جاوا اسکریپت بسیار آسان است.

⚙️ دستورالعمل‌ها:
با توجه به یک رشته، یک رشته جدید با ترتیب وارونه کاراکترها برگردانید.

مثال‌ها:

- reverse('apple') === 'leppa'
- reverse('hello') === 'olleh'
- reverse('Greetings!') === '!sgniteerG'

🔸 راه حل(ها):

- روش سریع و آسان:

function reverse(str) {
return str.split("").reverse().join("");
}
console.log(reverse("apple"));
// خروجی: 'leppa';


- استفاده از ()reduce:

function reverse(str) {
return str.split("").reduce((rev, char) => char + rev, "");
}
console.log(reverse("apple"));
// خروجی: 'leppa';


- استفاده از حلقه for of:

function reverse(str) {
let reversed = "";

for (let character of str) {
reversed = character + reversed;
}

return reversed;
}
console.log(reverse("apple"));
// خروجی: 'leppa';


2️⃣ وارونه کردن یک عدد صحیح

وارونه کردن یک عدد صحیح شبیه به وارونه کردن یک رشته است، با این تفاوت که باید نوع داده مقدار بازگشتی را به عدد تغییر دهید.

⚙️ دستورالعمل‌ها:
با توجه به یک عدد صحیح، یک عدد صحیح که ترتیب وارونه اعداد است برگردانید.

مثال‌ها:

- reverseInt(15) === 51
- reverseInt(981) === 189
- reverseInt(500) === 5
- reverseInt(-15) === -51
- reverseInt(-90) === -9

🔸 راه حل:

- استفاده از ()parseInt:

function reverseInt(n) {
const reversed = n.toString().split("").reverse().join("");

return parseInt(reversed) * Math.sign(n);
}
console.log(reverseInt(15));
// خروجی: 51


3️⃣ بزرگ کردن حروف اول یک رشته

⚙️ دستورالعمل‌ها:
یک تابع بنویسید که یک رشته را قبول کند. تابع باید حرف اول هر کلمه در رشته را بزرگ کند و سپس رشته بزرگ‌شده را برگرداند.

مثال‌ها:

- `capitalize('hello, there!')
➡️ 'Hello, There!'`

- `capitalize('a lazy fox')
➡️ 'A Lazy Fox'`

- `capitalize('look, it is working!')
➡️ 'Look, It Is Working!'`

🔸 راه حل(ها):

- با استفاده از حلقه for:

function capitalize(str) {
let result = str[0].toUpperCase();

for (let i = 1; i < str.length; i++) {
if (str[i - 1] === " ") {
result += str[i].toUpperCase();
} else {
result += str[i];
}
}

return result;
}
console.log(capitalize("hello, there!"));
// خروجی: 'Hello, There!'


- با استفاده از حلقه for of:

function capitalize(str) {
const words = [];

for (let word of str.split(" ")) {
words.push(word[0].toUpperCase() + word.slice(1));
}

return words.join(" ");
}
console.log(capitalize("hello, there!"));
// خروجی: 'Hello, There!'





📁 #javascript

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
👍31
اتاق برنامه نویسی </>
Photo
⚙️ URLSearchParams

یک ویژگی در جاوا اسکریپت است که امکان کار با پارامترهای کوئری (Query Parameters) موجود در URL‌ها را به شکلی ساده و کارآمد فراهم می‌کند. این پارامترها معمولاً پس از نماد ? در URL قرار می‌گیرند و برای ارسال اطلاعات اضافی به وب‌سایت‌ها استفاده می‌شوند.

🧐 چگونه استفاده می‌شود؟

1️⃣ ایجاد و دسترسی:

let params = new URLSearchParams(window.location.search);


این خط کد یک شیء URLSearchParams را از پارامترهای کوئری موجود در URL فعلی صفحه وب ایجاد می‌کند.

2️⃣ خواندن و تغییر دادن:

- برای خواندن مقادیر:

console.log(params.get('key')); // خواندن مقدار پارامتر 'key'


- برای افزودن یا تغییر دادن پارامترها:

params.append('newKey', 'newValue'); // افزودن پارامتر جدید
params.set('existingKey', 'newValue'); // تغییر مقدار پارامتر موجود


3️⃣ حذف و پاکسازی:

- برای حذف یک پارامتر خاص:

params.delete('key'); // حذف پارامتر 'key'


- برای پاک کردن همه پارامترها:

params.clear(); // پاک کردن تمام پارامترها


مثال:

فرض کنید URL شما این است:
http://example.com/?product=shirt&color=blue

let params = new URLSearchParams(window.location.search);
console.log(params.get('product')); // نتیجه: "shirt"
console.log(params.get('color')); // نتیجه: "blue"


🧩 مزایا:

- سادگی و خوانایی:
کار با پارامترهای کوئری URL به جای رشته‌های خام بسیار ساده‌تر است.

- سازگاری:
این ویژگی در اکثر مرورگرهای مدرن پشتیبانی می‌شود.

- انعطاف‌پذیری:
تغییر، اضافه کردن، و حذف پارامترها به راحتی امکان‌پذیر است.

🛠 کاربردها:

- ایجاد URLهای پیچیده برای API:
مدیریت پارامترهای دقیق برای درخواست‌های API.

- بررسی و تغییر پارامترهای کوئری:
بر اساس کاربرد کاربر در صفحه وب، مانند تغییر محتوا بر اساس انتخاب کاربر.

🔑 نکات امنیتی:

- هنگام استفاده از URLSearchParams، مهم است که به جلوگیری از تزریق کد ناخواسته توجه شود. همیشه مقادیر ورودی را تأیید کنید و از ایمن‌سازی آن‌ها در برابر حملات احتمالی اطمینان حاصل کنید.

📝 بنابراین، URLSearchParams یک ابزار قدرتمند در جاوا اسکریپت است که به توسعه‌دهندگان اجازه می‌دهد تا به راحتی با URLها کار کنند و تجربه کاربری بهتری را ارائه دهند.




📁 #javascript

کانال تخصصی لاراول
📌 @PapiDon_state

☕️ اتاق برنامه‌نویسی
📌 @PapiDon_coding
👍21
از کدام ویرایشگر متنی استفاده می‌کنی ؟
Anonymous Poll
0%
Vim
52%
VS Code
48%
PHPStorm ( JetBrains )