کانال آموزشی لاراول
3.06K subscribers
120 photos
4 videos
38 links
📌 کانال اتاق برنامه نویسی
@PapiDon_coding
Download Telegram
Success is not the result of one day of visible actions, but the result of consecutive days of small actions.

موفقیت نتیجه‌ی یک روزه انجام‌شدن اعمال قابل مشاهده نیست، بلکه نتیجه‌ی روزهای متوالی انجام‌شدن اعمال کوچک است


📌 @PapiDon_state
👍7🔥2👏21
📲 PWA ( Progressive Web Apps )

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

⚙️ کاربردهای PWA

1️⃣ بهبود سرعت بارگذاری وبسایت

2️⃣ کارکرد بدون اتصال به اینترنت

3️⃣ ارسال پوش نوتیفیکیشن

4️⃣ امکان اضافه کردن به صفحه اصلی دستگاه‌ها مانند یک اپلیکیشن موبایل

5️⃣ بهینه‌سازی مصرف داده‌ها

6️⃣ افزایش تعامل کاربر با وبسایت

تکنولوژی PWA

🔸Service Workers:
اسکریپت‌هایی که در پس‌زمینه اجرا می‌شوند و امکان کارکرد بدون اتصال به اینترنت، پیش‌بارگیری منابع و پوش نوتیفیکیشن‌ها را فراهم می‌آورند.

🔹Manifest:
فایلی به فرمت JSON است که اطلاعات مرتبط با نمایش و اجرای اپلیکیشن را برای استفاده در دستگاه‌های مختلف در بر دارد.

🔸Caching:
با استفاده از Service Workers، منابع وبسایت در دستگاه کاربر ذخیره می‌شوند، اکه این امر امکان بارگیری سریع‌تر و کارکرد بدون اتصال به اینترنت را فراهم می‌آورد.

📌@PapiDon_state
👍71
🔎 متد onError در Laravel چیست؟

متد ()onError به HTTP client افزوده شده که به شما این امکان را می‌دهد تا در صورت بروز خطایی هنگام ارسال یک درخواست HTTP، عملی خاص انجام دهید، مثل ثبت یک پیام خطا.

return $client->withHeaders($headers)
->post($url, $payload)
->onError(fn ($response) =>
Log::error('Twitter API failed posting Tweet', [
'url' => $url,
'payload' => $payload,
'headers' => $headers,
'response' => $response->body(),
])
)->json();

📌@PapiDon_state
👍91👏1
🧐 What is Pure Functions ?

توابع خالص یا Pure Functions مفهوم مهمی در برنامه‌نویسی هستند که دارای دو ویژگی اصلی می‌باشند:

1️⃣ خروجی ثابت: برای ورودی‌های مشابه، همیشه یک خروجی یکسان تولید می‌کنند.

2️⃣ عدم وجود اثرات جانبی (Side Effects): هیچ تغییری در وضعیت برنامه یا متغیرهای خارج از تابع ایجاد نمی‌کنند.

function add(a, b) {
return a + b;
}


این تابع با گرفتن دو عدد، جمع آن‌ها را بر می‌گرداند و هیچ Side Effect ندارد.

⚙️ مزایا :

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

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

🔹قابلیت ترکیب‌پذیری: توابع خالص می‌توانند راحت‌تر با یکدیگر ترکیب شوند تا وظایف پیچیده‌تری انجام دهند.

📌@PapiDon_state
👍21🔥1
🧐 What is Impure Functions ?

توابع ناخالص یا Impure Functions در مقابل توابع خالص قرار دارند و دو ویژگی اصلی دارند:

1️⃣ وابستگی به حالت خارجی: ممکن است به متغیرها یا حالت‌های خارجی وابسته باشند و خروجی‌شان تنها با توجه به ورودی‌ها قابل پیش‌بینی نباشد.

2️⃣ وجود Side Effect: مثل تغییر متغیرهای خارجی, انجام ورودی/خروجی و غیره.

let count = 0;

function increment() {
count++;
}


این تابع با گرفتن یک متغیر خارجی, مقدار آن را یک واحد افزایش می‌دهد.

⚠️ توابع ناخالص ممکن است پیچیدگی بیشتری به برنامه اضافه کنند و قابلیت تست و تحلیل برنامه را کاهش دهند. در برنامه‌نویسی تابعی, توصیه می‌شود که از توابع خالص بیشتری استفاده کنید تا برنامه‌ی ساده‌تر و قابل فهم‌تری داشته باشید.

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

📌@PapiDon_state
👍51🔥1
🔍 آشنایی با دستور distinct در لاراول

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

📌 مثلا، برای دریافت نام‌های منحصر به فرد کاربران:


$uniqueNames = DB::table('users')->distinct()->pluck('name');


📌 یا برای منحصر بودن بر اساس چندین ستون:


$uniqueData = DB::table('users')->select('account_id', 'email')->distinct()->get();

distinct
نتایج تکراری را حذف می‌کند و فقط نتایج منحصر به فرد را به شما نشان می‌دهد.


🔗 برای آموزش‌های بیشتر با ما همراه باشید!
📌 @PapiDon_state
👍156
🛠 Laravel Tinker

دستور tinker یک ابزار بی‌نظیر در لاراول است که به توسعه‌دهندگان این امکان را می‌دهد تا به صورت تعاملی در محیط کنسول با برنامه خود کار کنند. با استفاده از tinker می‌توانید دستورات PHP را اجرا کرده و با داده‌ها و اشیاء Laravel کار کنید، و همه اینها را بدون نیاز به ساخت یک مسیر HTTP انجام دهید.

💻 چگونه از tinker استفاده کنیم؟

برای دسترسی به این ابزار، در دایرکتوری ریشه پروژه Laravel خود، دستور زیر را وارد کنید:

php artisan tinker


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

* REPL (Read-Eval-Print Loop)

🔗 برای آموزش‌های بیشتر با ما همراه باشید!
📌 @PapiDon_state
👍122
🧐 تفاوت بین Factory و Seeder در Laravel:

🔹Factory:
- ایجاد داده تست بر اساس مدل‌ها
- استفاده از کتابخانه‌هایی مانند fzaninotto/faker برای تولید داده جعلی
- تولید داده‌های مرتبط با روابط (relationships)

🔸Seeder:
- ریختن داده‌ها در پایگاه داده
- کلاس‌های Seeder در database/seeders ذخیره می‌شوند
- کنترل ترتیب اجرای Seederها از طریق DatabaseSeeder


برای آموزش‌های بیشتر با ما همراه باشید!
📌 @PapiDon_state
👍6🙏51
What you do is what matters, not what you think or say or plan.

کاری که انجام می‌دهید مهم است، نه اینکه چه فکر یا چه حرف یا چه برنامه‌ای دارید. - " جیسون فراید"


📌 @PapiDon_state
👍71
کانال آموزشی لاراول
Photo
🛠 کوئری زدن در لاراول

در لاراول، با بهره‌گیری از توابع گوناگون، می‌توانید انواع جستجوها و کوئری‌ها را برای دیتابیس خود تنظیم و اجرا کنید.

1️⃣ whereNull:
- جستجوی سطرهایی که مقدار خاصی در یک ستون خالی است.
- 📌 User::whereNull('email_verified_at')->get();

2️⃣ whereDate:
- جستجوی سطرهایی با مقدار تاریخی خاص در یک ستون.
- 📌 User::whereDate('created_at', '2023-10-10')->get();

3️⃣ whereMonth:
- جستجوی سطرهایی با مقدار ماهی خاص در یک ستون تاریخی.
- 📌 User::whereMonth('created_at', '10')->get();

4️⃣ whereDay:
- جستجوی سطرهایی با مقدار روزی خاص در یک ستون تاریخی.
- 📌 User::whereDay('created_at', '10')->get();

5️⃣ whereYear:
- جستجوی سطرهایی با مقدار سالی خاص در یک ستون تاریخی.
- 📌 User::whereYear('created_at', '2023')->get();

6️⃣ whereTime:
- جستجوی سطرهایی با مقدار زمانی خاص در یک ستون.
- 📌 User::whereTime('created_at', '=', '10:00:00')->get();

7️⃣ whereColumn:
- مقایسه مقادیر دو ستون با یکدیگر و یافتن سطرهای مطابق.
- 📌 User::whereColumn('updated_at', '>', 'created_at')->get();

8️⃣ whereExists:
- جستجو بر اساس شرط موجود.
- 📌

   User::whereExists(function ($query) {
$query->select(DB::raw(1))
->from('orders')
->whereColumn('users.id', 'orders.user_id');
})->get();


📌 @PapiDon_state
👍72💯1
کانال آموزشی لاراول
Photo
🔍 توابع پیشرفته کوئری در لاراول

⚙️با استفاده از توابع زیر می‌توانید جستجوهای پیچیده‌تر و دقیق‌تری در دیتابیس خود انجام دهید:

1️⃣ whereBetween / orWhereBetween:
- بررسی می‌کند که آیا مقدار یک ستون بین دو مقدار مشخص است یا خیر.
- 📌 ->whereBetween('votes', [1, 100])

2️⃣ whereNotBetween / orWhereNotBetween:
- بررسی می‌کند که آیا مقدار یک ستون خارج از دو مقدار مشخص است یا خیر.
- 📌 ->whereNotBetween('votes', [1, 100])


3️⃣ whereBetweenColumns / orWhereBetweenColumns:
- بررسی می‌کند که آیا مقدار یک ستون بین مقادیر دو ستون دیگر در همان ردیف است یا خیر.
- 📌 ->whereBetweenColumns('weight', ['minimum_allowed_weight', 'maximum_allowed_weight'])


4️⃣ whereNotBetweenColumns / orWhereNotBetweenColumns:
- بررسی می‌کند که آیا مقدار یک ستون خارج از مقادیر دو ستون دیگر در همان ردیف است یا خیر.
- 📌 ->whereNotBetweenColumns('weight', ['minimum_allowed_weight', 'maximum_allowed_weight'])




برای آموزش‌های بیشتر با ما همراه باشید!
📌 @PapiDon_state
👍12🔥2
🔎 بررسی متد ()Array.prototype.flat

در برنامه‌نویسی با جاوااسکریپت، گاهی اوقات با آرایه‌های چند بعدی سر و کار داریم که نیاز داریم آن‌ها را به یک آرایه تک بعدی تبدیل کنیم. متد ()flat این کار را برای ما آسان می‌کند.

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

📜 مثال کد:

const multiDimensionalArray = [1, [2, 3], [4, [5, 6]]];

const flattenedArray = multiDimensionalArray.flat();

console.log(flattenedArray); // Output: [1, 2, 3, 4, [5, 6]]
در این مثال، ما یک آرایه چند بعدی داریم و با استفاده از متد `()flat`، آن را به یک آرایه تک بعدی تبدیل می‌کنیم.

const deeperFlattenedArray = multiDimensionalArray.flat(2);
console.log(deeperFlattenedArray);

// Output: [1, 2, 3, 4, 5, 6]
در این مثال، با تعیین عمق 2، هر دو سطح از آرایه هموار شده‌اند.


برای آموزش‌های بیشتر با ما همراه باشید!

📌 @PapiDon_state
👍14
👍7🔥42
🔹 معرفی متد mapWithKeys در لاراول 🔹

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

⚙️ نحوه کار با mapWithKeys

1️⃣ ابتدا یک کالکشن می‌سازیم:

use Illuminate\Support\Collection;

$collection = new Collection([
['name' => 'John', 'department' => 'Sales'],
['name' => 'Jane', 'department' => 'Finance']
]);


2️⃣ سپس متد mapWithKeys را فراخوانی کرده و یک تابع می‌دهیم که به ازای هر عنصر در کالکشن، یک آرایه از کلید/مقدار جدید برمی‌گرداند:

$grouped = $collection->mapWithKeys(function ($item, $key) {
return [$item['department'] => $item['name']];
});


3️⃣ در نهایت، ما یک آرایه جدید خواهیم داشت که در آن کلید‌ها نام بخش‌ها و مقادیر نام کارمندان است:

// $grouped will be:
// [
// 'Sales' => 'John',
// 'Finance' => 'Jane'
// ]


📌 @PapiDon_state
👍10
📘آشنایی با Notion: ابزاری جامع برای مدیریت اطلاعات و پروژه‌ها

🔹 آیا تا به حال با مشکل سازماندهی اطلاعات و پروژه‌های خود روبرو شده‌اید؟ Notion پاسخی کارآمد برای شما دارد!

🔸 یک پلتفرم یکپارچه است که به شما این امکان را می‌دهد تا:

📝 یادداشت‌هایتان را به راحتی بنویسید و مدیریت کنید.

🗂 وظایف و پروژه‌های خود را سازماندهی و پیگیری کنید.

📂 اسناد و فایل‌های مختلف را در یک مکان مرکزی ذخیره کنید.

🤝 با تیم‌تان به صورت آنلاین همکاری کنید و اطلاعات را به اشتراک بگذارید.

🔹 قابلیت‌های متنوع Notion شامل:
- ایجاد جداول و دیتابیس‌ها 📊
- طراحی برد‌ برای مدیریت وظایف 📋
- سفارشی‌سازی صفحات بر اساس نیازهای شما 🎨
- ادغام آسان با ابزارهای دیگر مانند Google Calendar, Slack و غیره 🔄

🔸 با Notion، همه چیز در یک مکان واحد و به خوبی سازماندهی شده است. پس از آن برای بهبود بهره‌وری خود و تیم‌تان استفاده کنید!

🔗 برای آغاز کار با Notion به
https://www.notion.so/
مراجعه کنید و اکانت رایگان خود را ایجاد کنید!


📌 @PapiDon_state
👍3🙏3
کانال آموزشی لاراول
Photo
🔹آماده‌سازی داده‌ها قبل از اعتبارسنجی با prepareForValidation

در لاراول، ما همیشه به دنبال تمیز و منظم کردن کدهایمان هستیم و می‌خواهیم اطمینان حاصل کنیم که داده‌هایی که کاربران ارسال می‌کنند، معتبر و آماده پردازش هستند. یکی از تکنیک‌های کاربردی برای این کار استفاده از متد prepareForValidation در کلاس‌های درخواست سفارشی (FormRequest) است.

🔸 چیستی prepareForValidation

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

🔸 چگونگی کار prepareForValidation

فرض کنید می‌خواهید هر درخواست برای ایجاد "موجودیت" جدید در سیستم شما حتما شامل user_id کاربری باشد که در حال ارسال درخواست است. به جای اینکه user_id را در هر فرم ورودی به صورت دستی اضافه کنید، می‌توانید این کار را در سمت سرور و در متد prepareForValidation انجام دهید. نگاهی به کد زیر بیندازید:

protected function prepareForValidation()
{
$this->merge([
'user_id' => $this->user()->id
]);
}

🔸 توضیح کد

در اینجا، ما از متد merge برای اضافه کردن user_id به داده‌های درخواست استفاده می‌کنیم. ()this->user$ به ما اطلاعات کاربری که در حال حاضر وارد شده است را می‌دهد و id آن، شناسه کاربر است. با این روش، user_id به صورت خودکار به درخواست اضافه می‌شود و نیازی نیست که کاربر آن را وارد کند.

🔸 مزایای استفاده از prepareForValidation

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

- تمیزی کد: جلوگیری از تکرار کد و حفظ DRY (Don't Repeat Yourself) در کدهای شما.

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

🔹 جمع‌بندی

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


به کانال ما بپیوندید تا بیشتر با لاراول و تکنیک‌های پیشرفته برنامه‌نویسی آشنا شوید!

📌 @PapiDon_state
👍13
کانال آموزشی لاراول
Photo
🔍 همه ما برنامه‌نویس‌ها می‌دونیم که کار با آرایه‌ها جزء جدایی‌ناپذیر کدنویسیه، اما گاهی اوقات با پیچیدگی‌هاش درگیر می‌شیم! 🤯 خوشبختانه لاراول یک جعبه ابزار داره که کار با آرایه‌ها رو لذت‌بخش می‌کنه.

یکی از این ابزارها، کلاس Arr است که مثل یک ابزار قدرتمند برای کار با آرایه‌ها عمل می‌کنه!

🛠 مثلاً، با استفاده از Arr::pluck می‌تونیم راحت از یک لیست بزرگ داده، فقط شماره‌های موبایل رو استخراج کنیم. فرض کنید ما یک آرایه از کاربران داریم و هر کاربر دارای اطلاعاتی مثل نام، ایمیل و شماره موبایل هست:


$users = [
['name' => 'علی', 'email' => 'ali@example.com', 'mobile' => '09123456789'],
['name' => 'زهرا', 'email' => 'zahra@example.com', 'mobile' => '09123456788'],
// و دیگر کاربران...
];

$mobiles = Arr::pluck($users, 'mobile');
// نتیجه: ['09123456789', '09123456788', ...]

اینجوری فقط با یک خط کد، شماره‌های موبایل رو جدا کردیم و دیگه نیازی به حلقه زدن دستی نداریم!

💡 پس اگه می‌خوای کدنویسی رو برای خودت راحت‌تر کنی، حتما از Arr در پروژه‌هات استفاده کن.

برای کدهای تمیزتر و سریع‌تر، فراموش نکن Illuminate\Support\Arr رو در بالای فایلت اضافه کنی. 😉

اگه ازش استفاده کردی یا اگر این مطلب واست مفید بود یه لایک بزن 😌


به کانال ما بپیوندید تا بیشتر با لاراول و تکنیک‌های پیشرفته برنامه‌نویسی آشنا شوید!

📌 @PapiDon_state
👍423🎉1