Laravel8.x核心特性全解析

好的,Laravel 8.x 引入了多项重要更新,主要特性如下:

1. 路由改进

  • 路由缓存优化 :支持缓存包含闭包路由的应用(需使用 Route::enforceSchema),提升性能。

  • 路由模型绑定简写:可直接在路由参数中使用模型类型提示:

    复制代码
    ```php
    use App\Models\User;
    Route::get('users/{user}', function (User $user) {
        return $user->email;
    });
    ```
  • 自定义路由键 :模型可通过 getRouteKeyName 方法定义绑定字段。

2. 模型工厂类

模型工厂从闭包升级为类:

php 复制代码
namespace Database\Factories;
use App\Models\User;
use Illuminate\Database\Eloquent\Factories\Factory;
class UserFactory extends Factory {
    protected $model = User::class;
    public function definition() {
        return [
            'name' => $this->faker->name,
            'email' => $this->faker->unique()->safeEmail,
        ];
    }
}

调用方式:

php 复制代码
User::factory()->count(5)->create();

3. 迁移文件压缩

使用 Schema::create 时支持 compressed 选项生成更小的迁移文件。

4. Blade 组件优化

  • 组件别名 :通过 component 方法注册别名:

    php 复制代码
    Blade::component('alert', AlertComponent::class);
  • 内联组件:可直接在模板中定义组件逻辑。

5. 事件监听器改进

支持基于接口的模型事件监听:

php 复制代码
use Illuminate\Contracts\Events\Dispatcher;
class UserObserver {
    public function creating(User $user) {
        // ...
    }
}

6. 队列批处理

新增 Bus::batch 方法管理队列任务批次:

php 复制代码
use Illuminate\Bus\Batch;
Batch::jobs([
    new ProcessPodcast,
    new SendNotification,
])->then(function (Batch $batch) {
    // 成功回调
})->catch(function (Batch $batch, Throwable $e) {
    // 失败处理
})->dispatch();

7. 测试辅助方法

  • assertDeleted:验证模型是否被软删除。
  • assertNotSoftDeleted:验证模型未被软删除。

8. Jetstream 与 Fortify

  • Jetstream:提供带有 Livewire/Inertia.js 的认证脚手架。
  • Fortify:作为 Jetstream 的后端引擎,处理注册、登录等核心逻辑。

9. 其他更新

  • rateLimiter:增强的请求频率限制器。

  • maintenance mode:维护模式支持预渲染视图。

  • time testing :测试时可通过 travel 方法模拟时间流逝:

    php 复制代码
    $this->travel(5)->minutes(); // 向前推进5分钟

注意:升级时需检查模型工厂、路由缓存等特性的兼容性。建议参考官方文档进行迁移。

相关推荐
战南诚1 小时前
mysql的坑 - count计数
数据库·mysql
薪火铺子1 小时前
MySQL 性能优化:慢查询与索引优化实战
数据库·mysql·性能优化
南境十里·墨染春水1 小时前
C++ 日志 4—— 多线程安全与异步日志优化
数据库·c++·安全
七夜zippoe2 小时前
DolphinDB索引设计:提升查询性能
数据库·索引·性能·查询·dolphindb
2401_898717662 小时前
HTML5中SVG原生动画标签Animate的基础用法
jvm·数据库·python
小江的记录本2 小时前
【MySQL】《MySQL基础架构 面试核心考点问答清单》
前端·数据库·后端·sql·mysql·adb·面试
猫的玖月2 小时前
(七)函数
android·数据库·sql
2401_867623982 小时前
mysql如何导出特定条件的查询数据_使用mysqldump加where参数
jvm·数据库·python
会编程的土豆2 小时前
MySQL 窗口函数详解
数据库·后端·mysql