Loading... * [Versioning Scheme](https://laravel.com/docs/10.x/releases#versioning-scheme) * [Support Policy](https://laravel.com/docs/10.x/releases#support-policy) * [Laravel 10](https://laravel.com/docs/10.x/releases#laravel-10) ## [Versioning Scheme](https://laravel.com/docs/10.x/releases#versioning-scheme) Laravel and its other first-party packages follow [Semantic Versioning](https://semver.org/). Major framework releases are released every year (~Q1), while minor and patch releases may be released as often as every week. Minor and patch releases should **never** contain breaking changes. When referencing the Laravel framework or its components from your application or package, you should always use a version constraint such as `^10.0`, since major releases of Laravel do include breaking changes. However, we strive to always ensure you may update to a new major release in one day or less. #### [Named Arguments](https://laravel.com/docs/10.x/releases#named-arguments) [Named arguments](https://www.php.net/manual/en/functions.arguments.php#functions.named-arguments) are not covered by Laravel's backwards compatibility guidelines. We may choose to rename function arguments when necessary in order to improve the Laravel codebase. Therefore, using named arguments when calling Laravel methods should be done cautiously and with the understanding that the parameter names may change in the future. ## [Support Policy](https://laravel.com/docs/10.x/releases#support-policy) For all Laravel releases, bug fixes are provided for 18 months and security fixes are provided for 2 years. For all additional libraries, including Lumen, only the latest major release receives bug fixes. In addition, please review the database versions [supported by Laravel](https://laravel.com/docs/10.x/database#introduction). | Version | PHP (*) | Release | Bug Fixes Until | Security Fixes Until | | --------- | ----------- | --------------------- | ------------------ | ---------------------- | | 8 | 7.3 - 8.1 | September 8th, 2020 | July 26th, 2022 | January 24th, 2023 | | 9 | 8.0 - 8.2 | February 8th, 2022 | August 8th, 2023 | February 6th, 2024 | | 10 | 8.1 - 8.2 | February 14th, 2023 | August 6th, 2024 | February 4th, 2025 | | 11 | 8.2 | Q1 2024 | August 5th, 2025 | February 3rd, 2026 | End of life Security fixes only (*) Supported PHP versions ## [Laravel 10](https://laravel.com/docs/10.x/releases#laravel-10) As you may know, Laravel transitioned to yearly releases with the release of Laravel 8. Previously, major versions were released every 6 months. This transition is intended to ease the maintenance burden on the community and challenge our development team to ship amazing, powerful new features without introducing breaking changes. Therefore, we have shipped a variety of robust features to Laravel 9 without breaking backwards compatibility. Therefore, this commitment to ship great new features during the current release will likely lead to future "major" releases being primarily used for "maintenance" tasks such as upgrading upstream dependencies, which can be seen in these release notes. Laravel 10 continues the improvements made in Laravel 9.x by introducing argument and return types to all application skeleton methods, as well as all stub files used to generate classes throughout the framework. In addition, a new, developer-friendly abstraction layer has been introduced for starting and interacting with external processes. Further, Laravel Pennant has been introduced to provide a wonderful approach to managing your application's "feature flags". ### [PHP 8.1](https://laravel.com/docs/10.x/releases#php-8) Laravel 10.x requires a minimum PHP version of 8.1. ### [Types](https://laravel.com/docs/10.x/releases#types) *Application skeleton and stub type-hints were contributed by [Nuno Maduro](https://github.com/nunomaduro)* . On its initial release, Laravel utilized all of the type-hinting features available in PHP at the time. However, many new features have been added to PHP in the subsequent years, including additional primitive type-hints, return types, and union types. Laravel 10.x thoroughly updates the application skeleton and all stubs utilized by the framework to introduce argument and return types to all method signatures. In addition, extraneous "doc block" type-hint information has been deleted. This change is entirely backwards compatible with existing applications. Therefore, existing applications that do not have these type-hints will continue to function normally. ### [Laravel Pennant](https://laravel.com/docs/10.x/releases#laravel-pennant) *Laravel Pennant was developed by [Tim MacDonald](https://github.com/timacdonald)* . A new first-party package, Laravel Pennant, has been released. Laravel Pennant offers a light-weight, streamlined approach to managing your application's feature flags. Out of the box, Pennant includes an in-memory `array` driver and a `database` driver for persistent feature storage. Features can be easily defined via the `Feature::define` method: ``` use Laravel\Pennant\Feature;use Illuminate\Support\Lottery; Feature::define('new-onboarding-flow', function() {returnLottery::odds(1, 10);}); ``` Once a feature has been defined, you may easily determine if the current user has access to the given feature: ``` if (Feature::active('new-onboarding-flow')) {// ...} ``` Of course, for convenience, Blade directives are also available: ``` @feature('new-onboarding-flow')<div><!-- ... --></div>@endfeature ``` Pennant offers a variety of more advanced features and APIs. For more information, please consult the [comprehensive Pennant documentation](https://laravel.com/docs/10.x/pennant). ### [Process Interaction](https://laravel.com/docs/10.x/releases#process) *The process abstraction layer was contributed by [Nuno Maduro](https://github.com/nunomaduro) and [Taylor Otwell](https://github.com/taylorotwell)* . Laravel 10.x introduces a beautiful abstraction layer for starting and interacting with external processes via a new `Process` facade: ``` use Illuminate\Support\Facades\Process; $result=Process::run('ls -la'); return$result->output(); ``` Processes may even be started in pools, allowing for the convenient execution and management of concurrent processes: ``` use Illuminate\Process\Pool;use Illuminate\Support\Facades\Process; [$first, $second, $third] =Process::concurrently(function(Pool$pool) {$pool->command('cat first.txt');$pool->command('cat second.txt');$pool->command('cat third.txt');}); return$first->output(); ``` In addition, processes may be faked for convenient testing: ``` Process::fake(); // ... Process::assertRan('ls -la'); ``` For more information on interacting with processes, please consult the [comprehensive process documentation](https://laravel.com/docs/10.x/processes). ### [Test Profiling](https://laravel.com/docs/10.x/releases#test-profiling) *Test profiling was contributed by [Nuno Maduro](https://github.com/nunomaduro)* . The Artisan `test` command has received a new `--profile` option that allows you to easily identify the slowest tests in your application: ``` php artisantest--profile ``` For convenience, the slowest tests will be displayed directly within the CLI output: ![](https://user-images.githubusercontent.com/5457236/217328439-d8d983ec-d0fc-4cde-93d9-ae5bccf5df14.png) ### [Pest Scaffolding](https://laravel.com/docs/10.x/releases#pest-scaffolding) New Laravel projects may now be created with Pest test scaffolding by default. To opt-in to this feature, provide the `--pest` flag when creating a new application via the Laravel installer: ``` laravel newexample-application--pest ``` ### [Generator CLI Prompts](https://laravel.com/docs/10.x/releases#generator-cli-prompts) *Generator CLI prompts were contributed by [Jess Archer](https://github.com/jessarcher)* . To improve the framework's developer experience, all of Laravel's built-in `make` commands no longer require any input. If the commands are invoked without input, you will be prompted for the required arguments: ``` php artisanmake:controller ``` ### [Horizon / Telescope Facelift](https://laravel.com/docs/10.x/releases#horizon-telescope-facelift) [Horizon](https://laravel.com/docs/10.x/horizon) and [Telescope](https://laravel.com/docs/10.x/telescope) have been updated with a fresh, modern look including improved typography, spacing, and design: ![](https://laravel.com/img/docs/horizon-example.png) Last modification:April 7, 2023 © Allow specification reprint Like 如果觉得我的文章对你有用,请随意赞赏