فصل پنج - Migrations and Database
بخش دوم - Factories
فکتوریها در لاراول ابزاری برای ایجاد سریع و راحت دادههای نمونه (mock) برای تست و توسعه هستند. با استفاده از فکتوریها، میتوانید به راحتی رکوردهایی را در پایگاه داده تولید کنید، بدون اینکه نیاز باشد به صورت دستی دادهها را وارد کنید.
در تستهای خودکار، میتوانید با استفاده از فکتوریها دادههای نمونه ایجاد کنید تا رفتار اپلیکیشن خود را آزمایش کنید.
ساخت یک فکتوری:
برای ساخت فکتوری، می توانید از دستور زیر استفاده کنید:
این دستور یک فکتوری با نام UserFactory برای شما در مسیر database/factories ایجاد می کند.
در فایل فکتوری که ایجاد شده، میتوانید دادههای پیشفرض را تعریف کنید.
مثال: تعریف یک فکتوری برای مدل User:
هر فیلد جدول، مقدار پیشفرضی در اینجا دارد که به صورت خودکار تولید میشود.
استفاده از فکتوری:
برای تولید یک رکورد در پایگاه داده:
این کد یک رکورد تست برای شما ایجاد می کند.
برای تولید چندین رکورد:
این کد به تعداد مشخص شده، رکورد تست برای شما ایجاد می کند.
برای ایجاد یک رکورد ولی بدون ذخیره کردن آن:
این کد یک رکورد تست برای شما ایجاد می کند اما در دیتابیس ذخیره نمی کند.
مثال کامل:
فرض کنید یک جدول برای مقالات (Posts) دارید.
این کد یک جمله رندوم برای noscript، یک پاراگراف رندوم برای content، و یک کاربر جدید برای user_id ایجاد می کند.
فرض کنید می خواهیم 100 پست تستی ایجاد کنیم:
این فکتوری به سادگی 100 پست تستی برای شما ایجاد خواهد کرد.
فکتوریها ابزاری قدرتمند برای تولید دادههای تستی و توسعه هستند.
به کمک آنها میتوانید بهسرعت دادههای مرتبط ایجاد کرده و تستهای خود را سادهتر و سریعتر انجام دهید.
فکتوریها انعطافپذیر هستند و میتوانید شرایط مختلف (مانند ایجاد رکوردهای مرتبط) را پیادهسازی کنید.
در پست های بعدی به طور کامل به فکتوری ها خواهیم پرداخت.
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
بخش دوم - Factories
فکتوریها در لاراول ابزاری برای ایجاد سریع و راحت دادههای نمونه (mock) برای تست و توسعه هستند. با استفاده از فکتوریها، میتوانید به راحتی رکوردهایی را در پایگاه داده تولید کنید، بدون اینکه نیاز باشد به صورت دستی دادهها را وارد کنید.
در تستهای خودکار، میتوانید با استفاده از فکتوریها دادههای نمونه ایجاد کنید تا رفتار اپلیکیشن خود را آزمایش کنید.
ساخت یک فکتوری:
برای ساخت فکتوری، می توانید از دستور زیر استفاده کنید:
php artisan make:factory UserFactory
این دستور یک فکتوری با نام UserFactory برای شما در مسیر database/factories ایجاد می کند.
در فایل فکتوری که ایجاد شده، میتوانید دادههای پیشفرض را تعریف کنید.
مثال: تعریف یک فکتوری برای مدل User:
class UserFactory extends Factory
{
protected $model = \App\Models\User::class;
public function definition()
{
return [
'name' => $this->faker->name(),
'email' => $this->faker->unique()->safeEmail(),
'email_verified_at' => now(),
'password' => bcrypt('password'),
'remember_token' => Str::random(10),
];
}
}
هر فیلد جدول، مقدار پیشفرضی در اینجا دارد که به صورت خودکار تولید میشود.
استفاده از فکتوری:
برای تولید یک رکورد در پایگاه داده:
User::factory()->create();
این کد یک رکورد تست برای شما ایجاد می کند.
برای تولید چندین رکورد:
User::factory()->count(10)->create();
این کد به تعداد مشخص شده، رکورد تست برای شما ایجاد می کند.
برای ایجاد یک رکورد ولی بدون ذخیره کردن آن:
$user = User::factory()->make();
این کد یک رکورد تست برای شما ایجاد می کند اما در دیتابیس ذخیره نمی کند.
مثال کامل:
فرض کنید یک جدول برای مقالات (Posts) دارید.
class PostFactory extends Factory
{
protected $model = \App\Models\Post::class;
public function definition()
{
return [
'noscript' => $this->faker->sentence(),
'content' => $this->faker->paragraph(),
'user_id' => \App\Models\User::factory(),
];
}
}
این کد یک جمله رندوم برای noscript، یک پاراگراف رندوم برای content، و یک کاربر جدید برای user_id ایجاد می کند.
فرض کنید می خواهیم 100 پست تستی ایجاد کنیم:
Post::factory()->count(100)->create();
این فکتوری به سادگی 100 پست تستی برای شما ایجاد خواهد کرد.
فکتوریها ابزاری قدرتمند برای تولید دادههای تستی و توسعه هستند.
به کمک آنها میتوانید بهسرعت دادههای مرتبط ایجاد کرده و تستهای خود را سادهتر و سریعتر انجام دهید.
فکتوریها انعطافپذیر هستند و میتوانید شرایط مختلف (مانند ایجاد رکوردهای مرتبط) را پیادهسازی کنید.
در پست های بعدی به طور کامل به فکتوری ها خواهیم پرداخت.
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
🔥7
فصل پنج - Migrations and Database
بخش دوم - Factories
لاراول هنگام کار با فکتوریها، مجموعهای از متدها و پراپرتیها را ارائه میدهد که به شما کمک میکنند دادههای نمونه پیشرفتهتری بسازید.
این متد ها درون کلاس فکتوری پیاده سازی می شوند.
1- متد definition
این متد اصلی ترین متد برای تعریف دادههای پیشفرض فکتوری استفاده میشود. دادههای تولید شده توسط Faker در این متد تعریف میشوند.
این متد یک آرایه برمی گرداند که شامل نام فیلد ها به عنوان key و مقدار فیلد ها به عنوان value می باشد.
2- متد unverified
این متد میتواند حالتی خاص برای فکتوری شما تعریف کند. مثلاً دادههایی را تولید کند که ایمیل کاربر تایید نشده باشد.
وقتی شما از متد unverified استفاده میکنید، در واقع یک وضعیت خاص برای فیلدها تعریف میکنید که باعث میشود برخی از فیلدها مانند email_verified_at برای رکوردهای ساخته شده، مقدار null داشته باشند.
این متد یک state جدید ایجاد می کند، یعنی می توانید برخی از مقادیر فیلدها را در unverified تغییر دهید بدون این که کل تعریف پیشفرض در متد definition را تغییر دهید.
3- متد suspended
یک حالت خاص دیگر (مانند unverified) برای دادهها تعریف میکند. این متد معمولاً برای افزودن وضعیت خاص به رکوردها استفاده میشود.
4- متد configure
متدی که به شما اجازه میدهد عملیات سفارشیسازی یا رویدادهایی را قبل یا بعد از ایجاد رکوردها اجرا کنید. معمولاً برای تنظیم مقادیر اضافی یا اعمال تغییرات خاص استفاده میشود.
این متد پس از اجرای متد craete به طور خودکار ایجاد می شود.
همچنین می توانید به جای afterCreating از afterMaking استفاده کنید درصورت استفاده از متد make.
5- متد newFactory
برای اتصال یک مدل به فکتوری استفاده میشود. این متد معمولاً در مدلها تعریف میشود و هدف اصلی آن مشخص کردن فکتوری مرتبط با مدل است تا بتوان به سادگی و بدون نیاز به تنظیم دستی، رکوردهای مدل را با استفاده از فکتوری تولید کرد.
درصورتی که نام مدل و فکتوری شما استاندارد باشد (مثلا User و UserFactory به ترتیب برای مدل و فکتوری)، لاراول به طور خودکار این عملیات را انجام می دهد.
در قسمت بعدی با تمامی متد های مرتبط با فکتوری که از مدل ها قابل فراخوانی هستند آشنا می شویم.
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
بخش دوم - Factories
لاراول هنگام کار با فکتوریها، مجموعهای از متدها و پراپرتیها را ارائه میدهد که به شما کمک میکنند دادههای نمونه پیشرفتهتری بسازید.
این متد ها درون کلاس فکتوری پیاده سازی می شوند.
1- متد definition
این متد اصلی ترین متد برای تعریف دادههای پیشفرض فکتوری استفاده میشود. دادههای تولید شده توسط Faker در این متد تعریف میشوند.
این متد یک آرایه برمی گرداند که شامل نام فیلد ها به عنوان key و مقدار فیلد ها به عنوان value می باشد.
class UserFactory extends Factory
{
protected $model = \App\Models\User::class;
public function definition()
{
return [
'name' => $this->faker->name(),
'email' => $this->faker->unique()->safeEmail(),
'password' => bcrypt('password'),
];
}
}
2- متد unverified
این متد میتواند حالتی خاص برای فکتوری شما تعریف کند. مثلاً دادههایی را تولید کند که ایمیل کاربر تایید نشده باشد.
وقتی شما از متد unverified استفاده میکنید، در واقع یک وضعیت خاص برای فیلدها تعریف میکنید که باعث میشود برخی از فیلدها مانند email_verified_at برای رکوردهای ساخته شده، مقدار null داشته باشند.
public function unverified()
{
return $this->state(function (array $attributes) {
return [
'email_verified_at' => null,
];
});
}
// Usage:
User::factory()->unverified()->create();
این متد یک state جدید ایجاد می کند، یعنی می توانید برخی از مقادیر فیلدها را در unverified تغییر دهید بدون این که کل تعریف پیشفرض در متد definition را تغییر دهید.
3- متد suspended
یک حالت خاص دیگر (مانند unverified) برای دادهها تعریف میکند. این متد معمولاً برای افزودن وضعیت خاص به رکوردها استفاده میشود.
public function suspended()
{
return $this->state(function (array $attributes) {
return [
'is_suspended' => true,
];
});
}
// Usage:
User::factory()->suspended()->create();
4- متد configure
متدی که به شما اجازه میدهد عملیات سفارشیسازی یا رویدادهایی را قبل یا بعد از ایجاد رکوردها اجرا کنید. معمولاً برای تنظیم مقادیر اضافی یا اعمال تغییرات خاص استفاده میشود.
public function configure()
{
return $this->afterCreating(function (User $user) {
$user->profile()->create([
'bio' => 'This is a sample bio.',
]);
});
}
// Usage:
User::factory()->create();
این متد پس از اجرای متد craete به طور خودکار ایجاد می شود.
همچنین می توانید به جای afterCreating از afterMaking استفاده کنید درصورت استفاده از متد make.
5- متد newFactory
برای اتصال یک مدل به فکتوری استفاده میشود. این متد معمولاً در مدلها تعریف میشود و هدف اصلی آن مشخص کردن فکتوری مرتبط با مدل است تا بتوان به سادگی و بدون نیاز به تنظیم دستی، رکوردهای مدل را با استفاده از فکتوری تولید کرد.
class User extends Authenticatable
{
use HasFactory;
protected static function newFactory()
{
return UserFactory::new();
}
}
درصورتی که نام مدل و فکتوری شما استاندارد باشد (مثلا User و UserFactory به ترتیب برای مدل و فکتوری)، لاراول به طور خودکار این عملیات را انجام می دهد.
در قسمت بعدی با تمامی متد های مرتبط با فکتوری که از مدل ها قابل فراخوانی هستند آشنا می شویم.
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
❤3
| AmirHossein |
متسفانه به دلیل مسائل امنیتی که توی کامیت های LaraGram به وجود اومده بود مجبور به حذف ریپوزیتوری شدم و خب 72 کامیت که داشت به علاوه استار ها حذف شدند برای اینکه از این نوع مسائل براتون پیش نیاد میتونه خوب باشه که قابلیت Secret scanning رو فعال کنید این قابلیت…
This media is not supported in your browser
VIEW IN TELEGRAM
Forwarded from | Erfan's Notes | via @DevelopixBot
⭕️ دوره آموزش برنامهنویسی مینی اپ تلگرام
💠 در این دوره به آموزش برنامهنویسی مینی اپ تلگرام میپردازیم، از مباحث پایه و عمومی شروع میکنیم و مفاهیم رو یاد میگیریم.
💠 در این دوره به آموزش برنامهنویسی مینی اپ تلگرام میپردازیم، از مباحث پایه و عمومی شروع میکنیم و مفاهیم رو یاد میگیریم.
🔥4👍1
فصل پنج - Migrations and Database
بخش دوم - Factories
در این قسمت به متد های مربوط به فکتوری ها و قابل فراخوانی از مدل ها می پردازیم.
1- متد factory
برای ایجاد یک فکتوری جدید استفاده میشود. در نسخههای قدیمی لاراول این متد به طور خودکار در دسترس بود، اما در نسخههای جدید لاراول باید از Model::factory() استفاده کنید.
در اینجا از متد factory برای تولید یک فکتوری از مدل User استفاده شده است.
2- متد create
برای ذخیره مدلهای تولیدشده در پایگاه داده استفاده میشود. این متد رکورد جدید را در دیتابیس ذخیره میکند.
در این مثال، کاربر جدیدی بر اساس فیلد های تعریف شده در UserFactory ایجاد و ذخیره میشود.
3- متد trashed
برای فیلتر کردن مدلهایی که در حالت soft delete قرار دارند، استفاده میشود. این متد برای زمانی که میخواهید فقط مدلهای حذفشده را ایجاد کنید مفید است.
در این مثال، کاربری که حذف شده است، ایجاد میشود.
4- متد make
مشابه create است اما رکورد را ذخیره نمیکند. این متد فقط شی مدل را برمیگرداند و هیچ تغییراتی در دیتابیس ایجاد نمیکند.
در اینجا، یک مدل جدید ساخته میشود اما در پایگاه داده ذخیره نمیشود.
5- متد count
برای مشخص کردن تعداد رکوردهایی است که باید ایجاد شوند.
در اینجا 10 کاربر ایجاد و در پایگاه داده ذخیره میشود.
6- متد suspended
معمولاً به عنوان یک حالت (state) در فکتوریها استفاده میشود. این متد یک وضعیت خاص (مثل تعلیق یا وضعیت غیر فعال) را به مدل اختصاص میدهد.
در اینجا، یک کاربر که در وضعیت تعلیق قرار دارد، ایجاد میشود.
7- متد state
برای اعمال حالتهای خاص (custom states) به مدلهای تولید شده استفاده میشود. این متد به شما این امکان را میدهد که ویژگیهای مدل را به صورت پویا تغییر دهید.
در اینجا، یک کاربر تولید میشود که ایمیل او تایید نشده است.
8- متد has
برای ایجاد روابط (مثل روابط hasMany) استفاده میشود. این متد به شما این امکان را میدهد که تعداد مدلهای وابسته (مانند پستها، کامنتها و غیره) را که باید به مدل اصلی تعلق داشته باشند مشخص کنید.
ابتدا یک کاربر جدید ایجاد میشود، سپس 5 پست مرتبط با این کاربر به طور خودکار ایجاد میشود.
ای متد نیاز به پیاده سازی روابط مربوطه در مدل های مربوطه می باشد.
9- متد hasXXX
این متد همان متد has می باشد اما به صورت داینامیک.
در اینجا، کاربری ایجاد میشود و به طور خودکار 3 پست برای او ایجاد میشود.
بخش Posts در متد hasPosts درواقع نام رابطه posts در مدل User می باشد.
10- متد for
برای تعریف یک رابطه به صورت خاص (معمولاً belongsTo) استفاده میشود. این متد به شما این امکان را میدهد که مدلهای وابسته را به مدل اصلی اختصاص دهید.
در اینجا، یک پست ایجاد میشود که به طور خودکار به یک کاربر جدید تعلق دارد.
11- متد forXXX
این متد همان متد for می باشد اما به صورت داینامیک.
در اینجا، یک پست برای یک کاربر مشخص ایجاد میشود.
بخش User در متد forUser درواقع رابطه user در مدل Post می باشد.
12- متد hasAttached
برای ایجاد روابط وابسته بین مدلها (مانند belongsToMany) استفاده میشود. این متد برای مدیریت روابط چند به چند (many-to-many) کاربرد دارد.
در اینجا، یک کاربر جدید ایجاد میشود و به طور خودکار به 3 نقش متصل میشود.
13- متد recycle
برای استفاده از یک مدل موجود (که قبلاً ایجاد شده یا حذف نرم شده) در روابط مختلف میان مدلها استفاده میشود. این متد به شما کمک میکند که یک مدل خاص را در فکتوریهای مختلف برای ایجاد رکوردهای مرتبط استفاده کنید تا یک نسخه واحد از آن مدل برای همه روابط در فرآیند ساخت دادهها استفاده شود.
در اینجا، ابتدا یک ایرلاین جدید ایجاد میشود، سپس متد recycle این ایرلاین را برای استفاده در بلیطها و پروازهایی که ایجاد میشوند، انتخاب میکند. درواقع ایرلاین ایجاد شده در تمام بلیطها و پروازهای موجود از قبل استفاده میشود.
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
بخش دوم - Factories
در این قسمت به متد های مربوط به فکتوری ها و قابل فراخوانی از مدل ها می پردازیم.
1- متد factory
برای ایجاد یک فکتوری جدید استفاده میشود. در نسخههای قدیمی لاراول این متد به طور خودکار در دسترس بود، اما در نسخههای جدید لاراول باید از Model::factory() استفاده کنید.
User::factory()->...
در اینجا از متد factory برای تولید یک فکتوری از مدل User استفاده شده است.
2- متد create
برای ذخیره مدلهای تولیدشده در پایگاه داده استفاده میشود. این متد رکورد جدید را در دیتابیس ذخیره میکند.
User::factory()->create();
در این مثال، کاربر جدیدی بر اساس فیلد های تعریف شده در UserFactory ایجاد و ذخیره میشود.
3- متد trashed
برای فیلتر کردن مدلهایی که در حالت soft delete قرار دارند، استفاده میشود. این متد برای زمانی که میخواهید فقط مدلهای حذفشده را ایجاد کنید مفید است.
User::factory()->trashed()->create();
در این مثال، کاربری که حذف شده است، ایجاد میشود.
4- متد make
مشابه create است اما رکورد را ذخیره نمیکند. این متد فقط شی مدل را برمیگرداند و هیچ تغییراتی در دیتابیس ایجاد نمیکند.
$user = User::factory()->make();
در اینجا، یک مدل جدید ساخته میشود اما در پایگاه داده ذخیره نمیشود.
5- متد count
برای مشخص کردن تعداد رکوردهایی است که باید ایجاد شوند.
User::factory()->count(10)->create();
در اینجا 10 کاربر ایجاد و در پایگاه داده ذخیره میشود.
6- متد suspended
معمولاً به عنوان یک حالت (state) در فکتوریها استفاده میشود. این متد یک وضعیت خاص (مثل تعلیق یا وضعیت غیر فعال) را به مدل اختصاص میدهد.
User::factory()->suspended()->create();
در اینجا، یک کاربر که در وضعیت تعلیق قرار دارد، ایجاد میشود.
7- متد state
برای اعمال حالتهای خاص (custom states) به مدلهای تولید شده استفاده میشود. این متد به شما این امکان را میدهد که ویژگیهای مدل را به صورت پویا تغییر دهید.
User::factory()->state([
'email_verified_at' => null,
])->create();
در اینجا، یک کاربر تولید میشود که ایمیل او تایید نشده است.
8- متد has
برای ایجاد روابط (مثل روابط hasMany) استفاده میشود. این متد به شما این امکان را میدهد که تعداد مدلهای وابسته (مانند پستها، کامنتها و غیره) را که باید به مدل اصلی تعلق داشته باشند مشخص کنید.
User::factory()->has(Post::factory()->count(5))->create();
ابتدا یک کاربر جدید ایجاد میشود، سپس 5 پست مرتبط با این کاربر به طور خودکار ایجاد میشود.
ای متد نیاز به پیاده سازی روابط مربوطه در مدل های مربوطه می باشد.
9- متد hasXXX
این متد همان متد has می باشد اما به صورت داینامیک.
User::factory()->hasPosts(3)->create();
در اینجا، کاربری ایجاد میشود و به طور خودکار 3 پست برای او ایجاد میشود.
بخش Posts در متد hasPosts درواقع نام رابطه posts در مدل User می باشد.
10- متد for
برای تعریف یک رابطه به صورت خاص (معمولاً belongsTo) استفاده میشود. این متد به شما این امکان را میدهد که مدلهای وابسته را به مدل اصلی اختصاص دهید.
Post::factory()->for(User::factory())->create();
در اینجا، یک پست ایجاد میشود که به طور خودکار به یک کاربر جدید تعلق دارد.
11- متد forXXX
این متد همان متد for می باشد اما به صورت داینامیک.
Post::factory()->forUser($user)->create();
در اینجا، یک پست برای یک کاربر مشخص ایجاد میشود.
بخش User در متد forUser درواقع رابطه user در مدل Post می باشد.
12- متد hasAttached
برای ایجاد روابط وابسته بین مدلها (مانند belongsToMany) استفاده میشود. این متد برای مدیریت روابط چند به چند (many-to-many) کاربرد دارد.
User::factory()->hasAttached(Role::factory(), 3)->create();
در اینجا، یک کاربر جدید ایجاد میشود و به طور خودکار به 3 نقش متصل میشود.
13- متد recycle
برای استفاده از یک مدل موجود (که قبلاً ایجاد شده یا حذف نرم شده) در روابط مختلف میان مدلها استفاده میشود. این متد به شما کمک میکند که یک مدل خاص را در فکتوریهای مختلف برای ایجاد رکوردهای مرتبط استفاده کنید تا یک نسخه واحد از آن مدل برای همه روابط در فرآیند ساخت دادهها استفاده شود.
Ticket::factory()->recycle(Airline::factory()->create())->create();
در اینجا، ابتدا یک ایرلاین جدید ایجاد میشود، سپس متد recycle این ایرلاین را برای استفاده در بلیطها و پروازهایی که ایجاد میشوند، انتخاب میکند. درواقع ایرلاین ایجاد شده در تمام بلیطها و پروازهای موجود از قبل استفاده میشود.
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
🔥4
درود به همه 🤝
دیشب حوصله م سر رفته بود و کاملا منطقی تصمیم گرفتم کتابخانه Laraquest که یک کتابخانه برای کار با ربات تلگرام به زبان PHP بود رو با زبان Go پیاده سازی کنم.
تا امروز مشغولش بود و تونستم یک نسخه از اون رو تحت عنوان پکیجی برای Go توسعه بدم.
- این پکیج هم مثل Laraquest که برای PHP بود دارای سینتکس هایلایتینگ خیلی پیشرفته ای هست که در تصاویر می تونید مشاهده کنید.
- در حال حاضر با اخرین نسخه Bot API همگام هست و شامل تمامی متد ها و آپدیت ها هست.
- سرعت قابل توجهی داره بدون در نظر گرفتم I/O همونطور که توی تصاویر هست 5 پیام رو حدود 50 میکرو ثانیه ارسال می کنه، یه چیزی معادل 0.05 میلی ثانیه.
- ساختار ساده ای هم برای توسعه ربات داره.
در آینده اگر مجدد حوصله م سر رفت فیچر های دیگه هم بهش اضافه میکنم، یا اگر کسی حوصله ش سر رفت اضافه کنه و PR بده.
اگر تصمیم گرفتید یک روز با Go ربات بزنید این پکیج رو فراموش نکنید.
در نهایت اگر مایل بودید با استار دادن از پروژه حمایت کنید. ❤️
Go Version:
https://github.com/laraXgram/Laraquest-Go
PHP Version:
https://github.com/laraXgram/Laraquest
@AmirhDeveloper
.
دیشب حوصله م سر رفته بود و کاملا منطقی تصمیم گرفتم کتابخانه Laraquest که یک کتابخانه برای کار با ربات تلگرام به زبان PHP بود رو با زبان Go پیاده سازی کنم.
تا امروز مشغولش بود و تونستم یک نسخه از اون رو تحت عنوان پکیجی برای Go توسعه بدم.
- این پکیج هم مثل Laraquest که برای PHP بود دارای سینتکس هایلایتینگ خیلی پیشرفته ای هست که در تصاویر می تونید مشاهده کنید.
- در حال حاضر با اخرین نسخه Bot API همگام هست و شامل تمامی متد ها و آپدیت ها هست.
- سرعت قابل توجهی داره بدون در نظر گرفتم I/O همونطور که توی تصاویر هست 5 پیام رو حدود 50 میکرو ثانیه ارسال می کنه، یه چیزی معادل 0.05 میلی ثانیه.
- ساختار ساده ای هم برای توسعه ربات داره.
در آینده اگر مجدد حوصله م سر رفت فیچر های دیگه هم بهش اضافه میکنم، یا اگر کسی حوصله ش سر رفت اضافه کنه و PR بده.
اگر تصمیم گرفتید یک روز با Go ربات بزنید این پکیج رو فراموش نکنید.
در نهایت اگر مایل بودید با استار دادن از پروژه حمایت کنید. ❤️
Go Version:
https://github.com/laraXgram/Laraquest-Go
PHP Version:
https://github.com/laraXgram/Laraquest
@AmirhDeveloper
.
❤7🔥3
فصل پنج - Migrations and Database
بخش سوم - Seeders
Seeder یکی از ابزارهای لاراول است که برای وارد کردن دادههای اولیه یا نمونه به پایگاه داده استفاده میشود. این ابزار به توسعهدهندگان کمک میکند تا دادههای لازم برای تست یا مقداردهی اولیه پایگاه داده را به صورت خودکار و سریع ایجاد کنند.
فرض کنید میخواهید جدول cities را با دادههای اولیه شهرها پر کنید. این جدول ممکن است شامل نام شهرها و استانهای آنها باشد.
1- ایجاد Seeder
ابتدا Seeder جدیدی برای جدول شهرها ایجاد میکنیم، این کار به وسیله دستور زیر انجام می شود:
2- پر کردن Seeder
فایل database/seeders/CitySeeder.php را باز کرده و دادههای اولیه را به صورت دستی وارد کنید:
3- اجرای Seeder
برای اجرای Seeder شهرها، از دستور زیر استفاده کنید:
یا برای اجرای تمامی سیدر ها:
گاهی در محیط پروداکشن سیدر ها ممکن است برای محافط از آسیب داده ها اجرا نشوند، برای این کار می توان از فلگ
پس از اجرای Seeder، جدول cities با داده های مشخص شده پر خواهد شد.
این روش برای مقداردهی اولیه دادههای ثابت مانند شهرها، دستهبندیها، یا تنظیمات بسیار مفید است و در زمان تست یا توسعه پروژه استفاده میشود.
استفاده از فکتوری ها در سیدر:
همچنین می توانید یک فکتوری را در سیدر خود فراخوانی کنید و داده های تستی خود را از فکتوری ایجاد کنید:
فراخوانی سیدر های اضافی در یک سیدر:
همچنین می توانید از متد call استفاده کنید و سیدر های دیگری را در سیدر خود فراخوانی و اجرا کنید:
بی صدا کردن رویداد های مدل:
درصورت اجرای سیدر و ایجاد رکورد ها، رویداد های مدل ها نیز فراخوانی می شوند، شما می توانید با استفاده از تریت WithoutModelEvents، می توانید مانع فراخوانی این سیدر ها شوید:
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
بخش سوم - Seeders
Seeder یکی از ابزارهای لاراول است که برای وارد کردن دادههای اولیه یا نمونه به پایگاه داده استفاده میشود. این ابزار به توسعهدهندگان کمک میکند تا دادههای لازم برای تست یا مقداردهی اولیه پایگاه داده را به صورت خودکار و سریع ایجاد کنند.
فرض کنید میخواهید جدول cities را با دادههای اولیه شهرها پر کنید. این جدول ممکن است شامل نام شهرها و استانهای آنها باشد.
1- ایجاد Seeder
ابتدا Seeder جدیدی برای جدول شهرها ایجاد میکنیم، این کار به وسیله دستور زیر انجام می شود:
php artisan make:seeder CitySeeder
2- پر کردن Seeder
فایل database/seeders/CitySeeder.php را باز کرده و دادههای اولیه را به صورت دستی وارد کنید:
namespace Database\Seeders;
use Illuminate\Database\Seeder;
use App\Models\City;
class CitySeeder extends Seeder
{
public function run()
{
$cities = [
['name' => 'Tehran', 'province' => 'Tehran'],
['name' => 'Mashhad', 'province' => 'Khorasan Razavi'],
['name' => 'Isfahan', 'province' => 'Isfahan'],
['name' => 'Shiraz', 'province' => 'Fars'],
['name' => 'Tabriz', 'province' => 'East Azerbaijan'],
];
foreach ($cities as $city) {
City::create($city);
}
// Or using query builder:
//City::insert($cities);
}
}
3- اجرای Seeder
برای اجرای Seeder شهرها، از دستور زیر استفاده کنید:
php artisan db:seed --class=CitySeeder
یا برای اجرای تمامی سیدر ها:
php artisan db:seed
گاهی در محیط پروداکشن سیدر ها ممکن است برای محافط از آسیب داده ها اجرا نشوند، برای این کار می توان از فلگ
—force استفاده کرد، اما مراقب داده های خود باشید:php artisan db:seed --force
پس از اجرای Seeder، جدول cities با داده های مشخص شده پر خواهد شد.
این روش برای مقداردهی اولیه دادههای ثابت مانند شهرها، دستهبندیها، یا تنظیمات بسیار مفید است و در زمان تست یا توسعه پروژه استفاده میشود.
استفاده از فکتوری ها در سیدر:
همچنین می توانید یک فکتوری را در سیدر خود فراخوانی کنید و داده های تستی خود را از فکتوری ایجاد کنید:
# UserSeeder.php
public function run(): void
{
User::factory()
->count(50)
->hasPosts(1)
->create();
}
فراخوانی سیدر های اضافی در یک سیدر:
همچنین می توانید از متد call استفاده کنید و سیدر های دیگری را در سیدر خود فراخوانی و اجرا کنید:
# FolanSeeder.php
public function run(): void
{
$this->call([
UserSeeder::class,
PostSeeder::class,
CommentSeeder::class,
]);
}
بی صدا کردن رویداد های مدل:
درصورت اجرای سیدر و ایجاد رکورد ها، رویداد های مدل ها نیز فراخوانی می شوند، شما می توانید با استفاده از تریت WithoutModelEvents، می توانید مانع فراخوانی این سیدر ها شوید:
class DatabaseSeeder extends Seeder
{
use WithoutModelEvents;
public function run(): void
{
$this->call([
UserSeeder::class,
]);
}
}
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
❤7
فصل پنج - Migrations and Database
بخش چهارم - اتصالات دیتابیس
در لاراول، مدیریت چندین اتصال به دیتابیس و استفاده از دیتابیسهای مختلف به صورت سادهای امکانپذیر است.
- چندین اتصال به دیتابیس
برای مدیریت چندین اتصال به دیتابیس فایل تنظیمات
مثال:
در اینجا دو کانکشن مختلف با نام های mysql و mysql_second را پیکربندی می کنیم.
——————
- استفاده از چندین کانکشن در کد
پس از تعریف کانکشنها در فایل تنظیمات، میتوانید به صورت زیر از آنها استفاده کنید:
همچنین در یک مدل خاص میتوانید کانکشن را مشخص کنید:
——————
- استفاده از MongoDB
برای استفاده از MongoDB در لاراول، میتوانید از پکیج رسمی
با استفاده از Composer، پکیج را به پروژه خود اضافه کنید:
پس از نصب پکیج، باید تنظیمات مربوط به اتصال به دیتابیس MongoDB را در فایل
پس از آن با کانکشن mongodb به دیتابیس mongodb خود متصل شوید.
——————
- استفاده از Redis در لاراول
لاراول به صورت داخلی از Redis پشتیبانی میکند.
تنظیمات Redis را می توانید در فایل
در این دوره استفاده از ردیس به طور کامل بررسی نمی شود، اما تمامی متد های ردیس از فساد Redis در دسترس هستند:
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
بخش چهارم - اتصالات دیتابیس
در لاراول، مدیریت چندین اتصال به دیتابیس و استفاده از دیتابیسهای مختلف به صورت سادهای امکانپذیر است.
- چندین اتصال به دیتابیس
برای مدیریت چندین اتصال به دیتابیس فایل تنظیمات
config/database.php را باز کنید. در آرایهی connections، میتوانید چندین کانکشن مختلف تعریف کنید.مثال:
'connections' => [
'mysql' => [
// ...
],
'mysql_second' => [
// ...
],
]
در اینجا دو کانکشن مختلف با نام های mysql و mysql_second را پیکربندی می کنیم.
——————
- استفاده از چندین کانکشن در کد
پس از تعریف کانکشنها در فایل تنظیمات، میتوانید به صورت زیر از آنها استفاده کنید:
// connect to 'mysql'
$data = DB::connection('mysql')->select('SELECT * FROM users');
// connect to 'mysql_second'
$data = DB::connection('mysql_second')->select('SELECT * FROM products');
// In migrations
public function up()
{
Schema::connection('mysql_second')->create('products', function (Blueprint $table) {
// ...
});
}
همچنین در یک مدل خاص میتوانید کانکشن را مشخص کنید:
class Product extends Model
{
protected $connection = 'mysql_second';
}
——————
- استفاده از MongoDB
برای استفاده از MongoDB در لاراول، میتوانید از پکیج رسمی
mongodb/laravel-mongodb استفاده کنید. این پکیج توسط MongoDB نگهداری میشود و ادغام کاملی با Eloquent و سایر ویژگیهای لاراول فراهم میکند. در ادامه، مراحل نصب و پیکربندی این پکیج را توضیح میدهم:با استفاده از Composer، پکیج را به پروژه خود اضافه کنید:
composer require mongodb/laravel-mongodb
پس از نصب پکیج، باید تنظیمات مربوط به اتصال به دیتابیس MongoDB را در فایل
config/database.php اضافه کنید. در بخش connections، کانکشن mongodb را به صورت زیر تعریف کنید:'connections' => [
// others...
'mongodb' => [
'driver' => 'mongodb',
'dsn' => env('MONGODB_URI', 'mongodb://localhost:27017'),
'database' => env('MONGODB_DATABASE', 'laravel_app'),
],
],
پس از آن با کانکشن mongodb به دیتابیس mongodb خود متصل شوید.
——————
- استفاده از Redis در لاراول
لاراول به صورت داخلی از Redis پشتیبانی میکند.
تنظیمات Redis را می توانید در فایل
config/database.php بررسی کنید.در این دوره استفاده از ردیس به طور کامل بررسی نمی شود، اما تمامی متد های ردیس از فساد Redis در دسترس هستند:
use Illuminate\Support\Facades\Redis;
Redis::set('key', 'value');
$value = Redis::get('key');
#laravel #لاراول #فصل_۵
@AmirhDeveloper
.
🔥9
| AmirHossein |
ایشالا تا سال دیگه ریلیز میشه (سال میلادی منظورمه🥰) ⭐️ LaraGram .
کامندهای Symfony که، توی Laravel هم استفاده شده و جدیدا توی LaraGram هم باز نویسی کردم، به قدری باهوش هستن که کافیه یک حرف از کامند رو بنویسی تا متوجه بشه.
اگر کامند هایی مثل m:c, ma:c, make:c, m:class یا هرچیز شبیه ش رو بزنید باز هم make:class رو متوجه میشه.
@Amirhdeveloper
اگر کامند هایی مثل m:c, ma:c, make:c, m:class یا هرچیز شبیه ش رو بزنید باز هم make:class رو متوجه میشه.
@Amirhdeveloper
🔥3👍2
Forwarded from | کانال توسعهدهندگان PHP |
❓ خروجی حلقه کدام است؟
1️⃣ Error
2️⃣ 10 9 8 7 6 5 4 3 2 1
3️⃣ Warning
4️⃣ 9 8 7 6 5 4 3 2 1 0
✅ پاسخ خود را همراه با توضیح ارائه دهید.
❗ بدون اجرای کد یا استفاده از هوش مصنوعی، کمی فکر کنید.
🔖 #PHP, #پی_اچ_پی, #چالش
👤 AmirHossein
💎 Channel: @DevelopixPHP
1️⃣ Error
2️⃣ 10 9 8 7 6 5 4 3 2 1
3️⃣ Warning
4️⃣ 9 8 7 6 5 4 3 2 1 0
✅ پاسخ خود را همراه با توضیح ارائه دهید.
❗ بدون اجرای کد یا استفاده از هوش مصنوعی، کمی فکر کنید.
🔖 #PHP, #پی_اچ_پی, #چالش
👤 AmirHossein
💎 Channel: @DevelopixPHP
👍1
Forwarded from | کانال توسعهدهندگان PHP |
🔰 در این سوال نکات زیادی حائز اهمیت است که معمولا در نظر گرفته نمیشود.
🔍 در ادامه، ساختار حلقه را بهطور مفصل بررسی میکنیم:
خروجی این حلقه بهصورت زیر خواهد بود:
⁉️ اما چرا؟
بیایید ساختار حلقه را از ابتدا بررسی کنیم.
🔰 ساختار کلی حلقه for
حلقه for از سه بخش تشکیل شده است:
1- شروع: مقداردهی اولیه متغیر حلقه.
این بخش تنها یک بار در ابتدای حلقه اجرا میشود.
2- شرط ادامه: تعیین میکند که آیا حلقه ادامه یابد یا متوقف شود.
این بخش در هر تکرار، قبل از اجرای بدنه اجرا شده و شرط اجرای بدنه را بررسی میکند.
3- تغییر مقدار: مقدار متغیر حلقه را تغییر میدهد.
این بخش پس از اجرای بدنه حلقه اجرا میشود.
🔰 بررسی اجرای حلقه ذکر شده
1- مقداردهی اولیه:
- ابتدا متغیر
2- بررسی شرط (
در این قسمت نکات مهمی وجود دارد:
- هر عدد به جز 0 مقدار true دارد، بنابراین تا زمانی که
- در عبارت
- - به همین دلیل عدد 0 نیز چاپ خواهد شد.
- - مقدار
اگر حلقه به این صورت نوشته میشد:
در این حالت، ابتدا مقدار
3- بررسی قسمت سوم (تغییر مقدار update)
- بخش سوم این حلقه روی مقدار
🔰 مرور روند اجرای حلقه ذکر شده
- مقدار دهی اولیه i با 10
- بررسی 10 == true، کاهش 10 به 9، چاپ 9
- بررسی 9 == true، کاهش 9 به 8، چاپ 8
.
.
.
- بررسی 2 == true، کاهش 2 به 1، چاپ 1
- بررسی 1 == true، کاهش 1 به 0، چاپ 0
- بررسی 0 == true، پایان حلقه
❗️ درک درست post-decrement ($i--) و pre-decrement (--$i) در حلقهها اهمیت زیادی دارد و تفاوتهای ظریفی در خروجی ایجاد میکند.
🔖 #PHP, #پی_اچ_پی, #چالش
👤 AmirHossein
💎 Channel: @DevelopixPHP
🔍 در ادامه، ساختار حلقه را بهطور مفصل بررسی میکنیم:
for ($i = 10; $i--; $i > 0) {
echo "$i ";
}خروجی این حلقه بهصورت زیر خواهد بود:
9 8 7 6 5 4 3 2 1 0⁉️ اما چرا؟
بیایید ساختار حلقه را از ابتدا بررسی کنیم.
🔰 ساختار کلی حلقه for
حلقه for از سه بخش تشکیل شده است:
1- شروع: مقداردهی اولیه متغیر حلقه.
این بخش تنها یک بار در ابتدای حلقه اجرا میشود.
2- شرط ادامه: تعیین میکند که آیا حلقه ادامه یابد یا متوقف شود.
این بخش در هر تکرار، قبل از اجرای بدنه اجرا شده و شرط اجرای بدنه را بررسی میکند.
3- تغییر مقدار: مقدار متغیر حلقه را تغییر میدهد.
این بخش پس از اجرای بدنه حلقه اجرا میشود.
🔰 بررسی اجرای حلقه ذکر شده
1- مقداردهی اولیه:
- ابتدا متغیر
$i مقدار 10 میگیرد و اجرای این بخش پایان مییابد.2- بررسی شرط (
$i--)در این قسمت نکات مهمی وجود دارد:
- هر عدد به جز 0 مقدار true دارد، بنابراین تا زمانی که
$i به 0 نرسد، حلقه ادامه خواهد داشت.- در عبارت
$i-- از عملیات post-decrement استفاده شده است، یعنی ابتدا مقدار فعلی $i برای بررسی شرط استفاده میشود، سپس مقدار $i کاهش مییابد.- - به همین دلیل عدد 0 نیز چاپ خواهد شد.
- - مقدار
$i بعد از کاهش وارد بدنه حلقه میشود، بنابراین چاپ اعداد از 9 شروع میشود.اگر حلقه به این صورت نوشته میشد:
for ($i = 10; --$i; $i > 0) {
echo "$i ";
}در این حالت، ابتدا مقدار
$i کاهش مییابد و سپس شرط بررسی میشود زیرا از عملیات pre-decrement، بنابراین 0 چاپ نمیشود و خروجی به این شکل خواهد بود:9 8 7 6 5 4 3 2 13- بررسی قسمت سوم (تغییر مقدار update)
- بخش سوم این حلقه روی مقدار
$i تغییری ایجاد نمیکند، بنابراین عملاً بیاثر است و میتوان حلقه را سادهتر نوشت:for ($i = 10; $i--;) {
echo "$i ";
}🔰 مرور روند اجرای حلقه ذکر شده
- مقدار دهی اولیه i با 10
- بررسی 10 == true، کاهش 10 به 9، چاپ 9
- بررسی 9 == true، کاهش 9 به 8، چاپ 8
.
.
.
- بررسی 2 == true، کاهش 2 به 1، چاپ 1
- بررسی 1 == true، کاهش 1 به 0، چاپ 0
- بررسی 0 == true، پایان حلقه
❗️ درک درست post-decrement ($i--) و pre-decrement (--$i) در حلقهها اهمیت زیادی دارد و تفاوتهای ظریفی در خروجی ایجاد میکند.
🔖 #PHP, #پی_اچ_پی, #چالش
👤 AmirHossein
💎 Channel: @DevelopixPHP
🔥4👍2❤1
| AmirHossein |
حدود یک سال از شروع توسعه LaraGram میگذره و امروز ورژن 2 اون منتشر شد. توی این ورژن LaraGram کاملا از نو بازسازی شده با الهام گیری از فریمورک Laravel در ابتدا Container اضافه شده که مسئول مدیریت تمام وابستگی های پروژه هست. از طرفی ServiceProvider ها رابط…
7 ماهی از انتشار ورژن 2 گذشته و ورژن 3 درحال توسعه هست.
توی ورژن 3 تغییرات زیادی مخصوصا در پرفورمنس اعمال شده؛
سیستم های کش اکثر بخش های فریمورک رو در بر گرفتن.
همچنین Eloquent ORM به صورت کاملا اختصاصی بازنویسی شده.
دلیل این بازنویسی این هست که، این ORM برای اجرا نیاز به کانتینر، ایونتها، کیوها، و کلی چیز دیگه از لاراول داره.
ما همه این سیستم هارو توی LaraGram داریم، ولی الوکوئنت دقیقا برای لاراول رو نیاز داره، به همین دلیل در کنار کانتینر LaraGram باید کانتینر Laravel هم لود بشه که منطقی نیست.
اما این بازنویسی تمامی وابستگی های خارجی رو حذف کرده و سرعت دوبرابر بهتر شده.
از طرفی دو کرنل HTTP و Console اضافه شدن؛
کامند ها و درخواست ها به طور دقیق بررسی میشن، Gateها و Middlewareها روی اون ها اعمال میشن و خطاها به طور دقیق مدیریت میشن.
سیستم چندزبانی اصافه شده.
قابلیت مدیریت اتصال و توسعه چند ربات همزمان اضافه میشه.
سیستمی تحت عنوان کامپوننت قراره اضافه بشه، که راستش خودم نمیدونم چی هست فقط میدونم قراره قابلیت باز استفاده از ماژول ها یا هرچیزی رو با فراخوانی یک تابع بده.
مثلا شما نیاز نیست سیستم عضویت اجباری توسعه بدید، کافیه کامپوننت اون رو لود کنید.
سیستم کیو و جاب اضافه میشه که میتونید به سادگی عملیات های زمان بندی شده رو توسعه بدید.
قابلیت های جزئی هم طی توسعه اضافه میشن.
و در نهایت احتمال اضافه شدن پروتکل MTProto در ورژن 3 هست؛
توسعه ش یکم سخت و زمانبر هست، برای همین قول نمیدم توی ورژن 3 بیاد، شاید توی ورژن 4 اضافه بشه، ولی میشه یک روز.
و احتمالا چیزای دیگه که در آینده به ذهنم برسه.
اگر ایده یا پیشنهادی دارید خوشحال میشم درمیون بذارید، یا توی توسعه کمک کنید.
و اگر هم به پروژه استار بدید که خیلی بیشتر خوشحال میشم❤️
- LaraGram
- Laraquest
- Core
@AmirhDeveloper
.
توی ورژن 3 تغییرات زیادی مخصوصا در پرفورمنس اعمال شده؛
سیستم های کش اکثر بخش های فریمورک رو در بر گرفتن.
همچنین Eloquent ORM به صورت کاملا اختصاصی بازنویسی شده.
دلیل این بازنویسی این هست که، این ORM برای اجرا نیاز به کانتینر، ایونتها، کیوها، و کلی چیز دیگه از لاراول داره.
ما همه این سیستم هارو توی LaraGram داریم، ولی الوکوئنت دقیقا برای لاراول رو نیاز داره، به همین دلیل در کنار کانتینر LaraGram باید کانتینر Laravel هم لود بشه که منطقی نیست.
اما این بازنویسی تمامی وابستگی های خارجی رو حذف کرده و سرعت دوبرابر بهتر شده.
از طرفی دو کرنل HTTP و Console اضافه شدن؛
کامند ها و درخواست ها به طور دقیق بررسی میشن، Gateها و Middlewareها روی اون ها اعمال میشن و خطاها به طور دقیق مدیریت میشن.
سیستم چندزبانی اصافه شده.
قابلیت مدیریت اتصال و توسعه چند ربات همزمان اضافه میشه.
سیستمی تحت عنوان کامپوننت قراره اضافه بشه، که راستش خودم نمیدونم چی هست فقط میدونم قراره قابلیت باز استفاده از ماژول ها یا هرچیزی رو با فراخوانی یک تابع بده.
مثلا شما نیاز نیست سیستم عضویت اجباری توسعه بدید، کافیه کامپوننت اون رو لود کنید.
سیستم کیو و جاب اضافه میشه که میتونید به سادگی عملیات های زمان بندی شده رو توسعه بدید.
قابلیت های جزئی هم طی توسعه اضافه میشن.
و در نهایت احتمال اضافه شدن پروتکل MTProto در ورژن 3 هست؛
توسعه ش یکم سخت و زمانبر هست، برای همین قول نمیدم توی ورژن 3 بیاد، شاید توی ورژن 4 اضافه بشه، ولی میشه یک روز.
و احتمالا چیزای دیگه که در آینده به ذهنم برسه.
اگر ایده یا پیشنهادی دارید خوشحال میشم درمیون بذارید، یا توی توسعه کمک کنید.
و اگر هم به پروژه استار بدید که خیلی بیشتر خوشحال میشم❤️
- LaraGram
- Laraquest
- Core
@AmirhDeveloper
.
5🔥11
Forwarded from Learning with Zmat24 (Matin Soleymani)
Laravel 11.42 ✅❤️
یه سری شورتکات برای تاریخ توی الکوئنت اضافه شده که باهم مرور میکنیم.
همشون مشخصه چیکار میکنند ولی یه توضیح ریز هم خواهیم داشت.
1. wherePast
✳️ فیلدی که ورودی میدید رو با تاریخ امروز مقایسه میکنه در صورتی که گذشته باشه برمیگردونه.
2. whereToday
✳️ اگر فیلیدی که ورودی میدید با تاریخ امروز یکسان باشه برمیگردونه.
3. whereFuture
✳️ فیلدی که وروردی میدید رو با تاریخ امروز مقایسه میکنه در صورتی که آینده باشه برمیگردونه.
4. whereNowOrFuture
✳️ فیلدی که وروردی میدید رو با تاریخ امروز مقایسه میکنه در صورتی که آینده باشه یا با تاریخ امروز یکسان باشه برمیگردونه.
5. whereNowOrPast
✳️ فیلدی که وروردی میدید رو با تاریخ امروز مقایسه میکنه در صورتی که گذشته باشه یا با تاریخ امروز یکسان باشه برمیگردونه.
و چندتا تغییر دیگه که میتونید خودتون مطالعه کنید.
یه سری شورتکات برای تاریخ توی الکوئنت اضافه شده که باهم مرور میکنیم.
همشون مشخصه چیکار میکنند ولی یه توضیح ریز هم خواهیم داشت.
1. wherePast
✳️ فیلدی که ورودی میدید رو با تاریخ امروز مقایسه میکنه در صورتی که گذشته باشه برمیگردونه.
2. whereToday
✳️ اگر فیلیدی که ورودی میدید با تاریخ امروز یکسان باشه برمیگردونه.
3. whereFuture
✳️ فیلدی که وروردی میدید رو با تاریخ امروز مقایسه میکنه در صورتی که آینده باشه برمیگردونه.
4. whereNowOrFuture
✳️ فیلدی که وروردی میدید رو با تاریخ امروز مقایسه میکنه در صورتی که آینده باشه یا با تاریخ امروز یکسان باشه برمیگردونه.
5. whereNowOrPast
✳️ فیلدی که وروردی میدید رو با تاریخ امروز مقایسه میکنه در صورتی که گذشته باشه یا با تاریخ امروز یکسان باشه برمیگردونه.
و چندتا تغییر دیگه که میتونید خودتون مطالعه کنید.
🔥7
توی لاراول 12 با زدن کامند:
میتونیم لاراول رو اجرا کنیم.
این روش به طور خودکار کامندهای:
رو اجرا میکنه.
البته میتونیم توی لاراول های قدیمی تر هم با اضافه کردن noscript اون به فایل composer.json این قابلیت رو داشته باشیم.
@AmirhDeveloper
.
composer run dev
میتونیم لاراول رو اجرا کنیم.
این روش به طور خودکار کامندهای:
php artisan serve
php artisan queue:listen --tries=1
php artisan pail --timeout=0
npm run dev
..
رو اجرا میکنه.
البته میتونیم توی لاراول های قدیمی تر هم با اضافه کردن noscript اون به فایل composer.json این قابلیت رو داشته باشیم.
@AmirhDeveloper
.
🔥6❤4👍1
| AmirHossein |
درود به همه قصد نوشتن یک دوره آموزشی جامع و کامل برای فریمورک قدرتمند لاراول رو دارم. این دوره به صورت گام به گام و از مباحث پایه شروع شده و به تدریج به مباحث پیشرفتهتر میپردازه، و هر چیزی از لاراول رو قراره پوشش بده. مناسب برای همه، حتی کسانی که هیچ…
از فردا فصل 6 رو شروع میکنیم.
🔥8