前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Laravel 5.5 LTS 正式发布!

Laravel 5.5 LTS 正式发布!

作者头像
overtrue
发布2018-07-05 15:08:02
2.5K0
发布2018-07-05 15:08:02
举报

千呼万唤始出来~等了那么久的新一代 LTS!距离上一代 LTS (即 5.1)感觉已经好遥远了呢!新版的 LTS 同样会有为期两年的 Bug 修复和三年的安全更新!而其他对于一般的发行版则是提供六个月的 Bug 修复支持,一年的安全修复支持。

按照惯例,接下来让我们罗列一下新版的特性~

Whoops 回归

用过 Laravel 4 的人都会喜欢的 Whoops 错误处理框架,它已经在 5.5 正式回归了!

集合 Dump

一个能让你在集合中直接使用 dd 的新功能。

代码语言:javascript
复制
<?php

Song::all()
    ->filter
    ->platinum
    ->dump()
    ->filter(function ($song) {
        return $song->released_on >= \Carbon\Carbon::parse('-10 years');
    })
    ->dd();

异常渲染

如果定义了一个公共「响应」方法就可以对异常进行渲染。 在早期的 Laravel 版本中,你可以在 App\Exceptions\Handler::render() 方法添加检查,并有条件地基于异常类型来返回响应。

在 5.5 中,你可以直接抛出异常,而无需在处理程序中添加额外的逻辑进行响应:

代码语言:javascript
复制
<?php

// throw new TerribleSongException($song) in a controller...

namespace App\Exceptions;

use App\Song;

class TerribleSongException extends \Exception
{
    /**
     * @var \App\Song
     */
    protected $song;

    public function __construct(Song $song)
    {
        $this->song = $song;
    }

    /**
     * @param \Illuminate\Http\Request $request
     */
    public function render($request)
    {
        return response("The song '{$this->song->title}' by '{$this->song->artist}' is terrible.");    
    }
}

你还可以在异常类中实现 Responsable 接口,Laravel 将自动响应。

Responsable 响应接口

Laravel 为响应方法新增了一个 Responsable 接口。 实现接口的类可以从控制器方法返回。在准备响应到 Illuminate\Routing\Router 时,路由器会检查 Responsable 的实例。

这是一个将响应的内容交给 NewSongResponse 对象来处理的例子:

代码语言:javascript
复制
public function store(Request $request){
    $data = request()->validate([
        'title' => 'required',
        'artist' => 'required',
        'description' => 'required',
        'duration' => 'required|numeric',
        'released_on' => 'required|date_format:Y-m-d',
        'gold' => 'boolean',
        'platinum' => 'boolean',
    ]);

    $song = new Song($data);
    $song->save();

    return new NewSongResponse($song);
}

现在我们来看看这个 NewSongResponse 的类:

代码语言:javascript
复制
<?php

namespace App\Http\Responses;

use App\Song;
use Illuminate\Contracts\Support\Responsable;

class NewSongResponse implements Responsable
{
    /**
     * @var \App\Song
     */
    protected $song;

    /**
     * @param \App\Song $song
     */
    public function __construct(Song $song)
    {
       $this->song = $song; 
    }

    public function toResponse($request)
    {
        if ($request->wantsJson()) {
            return response()
                ->json($this->song)
                ->header('Location', route('songs.show', $this->song))
                ->setStatusCode(201);
        }

        return redirect()
            ->route('songs.show', $this->song);
    }
}

如你所见,在默认情况下,程序会重定向到路由 songs.show,而如果是通过 AJAX 发出的请求,就会自动响应 JSON 格式的内容。

请求中的验证方法

在 Laravel 的过去版本中,你可以将请求实例传递给控制器中的 $this->validate() 方法:

代码语言:javascript
复制
$this->validate(request(), [...]);

现在,你可以直接在请求对象上调用 validate 方法:

代码语言:javascript
复制
$data = request()->validate([
    'title' => 'required',
    'artist' => 'required',
    'description' => 'required',
    'duration' => 'required|numeric',
    'released_on' => 'required|date_format:Y-m-d',
    'gold' => 'boolean',
    'platinum' => 'boolean',
]);

用这种方式来调用验证的另一个好处是返回值的作用就像 Request::only(),只返回验证规则中提供的键。 这样就可以省去对 Request::all() 的使用。

自定义验证规则

自定义验证类,是旧版 Validator::extend(仍然可以使用)拓展自定义规则一个替代方式。之所以这样做,是因为这样做能够让规则逻辑更加一目了然。 你可以像下面这样创建一个自定义验证类:

代码语言:javascript
复制
<?php

namespace App\Rules;

use Illuminate\Contracts\Validation\Rule;

class CowbellValidationRule implements Rule
{
    public function passes($attribute, $value)
    {
        return $value > 10;
    }

    public function message()
    {
        return ':attribute needs more cowbell!';
    }
}

然后这样来使用:

代码语言:javascript
复制
<?php

request()->validate([
    'cowbells' => [new CowbellValidationRule],
    'more_cowbells' => [function ($attribute, $value, $fail) {
        if ($value <= 10) {
            $fail(':attribute needs more cowbell!');
        }
    }]
]);

以上示例使用闭包来对属性的值的校验,如果验证失败,则返回失败参数。 而在你中规中矩的把验证内容搬到专用规则对象类之前,又或者仅仅只是一次性验证的场景,用闭包来测试自定义的验证规则是最合适不过的。

你可以使用新的 make:rule 命令创建自定义验证规则类:

代码语言:javascript
复制
$ php artisan make:rule MyCustomRule

Blade 模板命令 Auth & Guest

新功能文章列表中也有提到过 Blade::if () 指令。 而 @auth 和 @guest 是新增的条件指令。

一般来说,你可能会在 Blade 模板中使用以下写法来判断的用户的登录情况:

代码语言:javascript
复制
@if(auth()->check())
    {{ -- authenticated --}}
@endif

@if(auth()->guest())

现在,你可以简单的使用这两个新指令来实现这一效果:

代码语言:javascript
复制
@auth
    Welcome {{ user()->name }}!
@endauth

@guest
    Welcome Guest!
@endguest

前端预设

默认情况下 Laravel 5.5 为所有的新项目提供了 Vue.js 作为前端脚手架。但是,新版的 Laravel 允许你使用 Artisan命令 preset 删除所有前端脚手架,再从几个预设中重新进行选择。

通过运行 php artisan help preset 命令,你可以看到可供选择的内容有:none、bootstrap、vu 以及 react:

代码语言:javascript
复制
php artisan help preset
Usage:
  preset <type>

Arguments:  
    type    The preset type (none, bootstrap, vue, react)

# 使用 react
$ php artisan preset react

# 清除脚手架
$ php artisan preset none

分离工厂文件

之前的版本都是在 ModelFactory.php 文件中定义所有模型工厂。而现在,你可以为每个模型创建不同的文件。在运行创建新模型的命令时加上 -fm 选项可以为其创建工厂文件:

代码语言:javascript
复制
$ php artisan make:model -fm Post

# 或者你也可以在创建模型的时候,使用 --all 同时创建控制器、迁移和工厂
$ php artisan make:model --all

当然也可以直接使用 make:factory 来创建工厂文件:

代码语言:javascript
复制
$ php artisan make:factory --model=Example ExampleFactory

migrate:fresh 迁移命令

5.5 中新的 migrate:fresh 迁移命令能让你在开发中轻松地创建一个干净数据库。 这条命令可以自动为你删除所有数据库表并且运行迁移。

这听起来很像 migrate:refresh 命令,它会回滚并重新迁移。但通常在开发过程中,你会更倾向于一口气删除所有表再来运行迁移。而 migrate:fresh 做的正是这件事情。

RefreshDatabase Trait

RefreshDatabase trait 是在测试期间迁移数据库的新方式。根据你是否使用内存数据库或传统数据库,这会是迁移测试数据库的最佳方法。 DatabaseTransactionsDatabaseMigrations trait 仍然能在 5.5 中不使用新的 RefreshDatabase trait 的情况下进行升级。

withoutExceptionHandling() 方法

基本测试用例继承了一个 withoutExceptionHandling() 方法,它能够禁用测试的异常处理。禁用异常处理之后就可以在测试中捕获异常,声明异常,而不是响应异常处理程序。如果你想要查看实际的异常状况时,这会是一个很有用的调试工具。

包自动发现

虽然 Laravel 包不会很难安装,但是有了包自动发现功能之后,你就可以不用在服务容器中设置提供器或别名。甚至,你还可以禁用特定软件包的自动发现~

人生苦短 我用 Laravel

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2017-08-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 假装我会写代码 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Whoops 回归
  • 集合 Dump
  • 异常渲染
  • Responsable 响应接口
  • 请求中的验证方法
  • 自定义验证规则
  • Blade 模板命令 Auth & Guest
  • 前端预设
  • 分离工厂文件
  • migrate:fresh 迁移命令
  • RefreshDatabase Trait
  • withoutExceptionHandling() 方法
  • 包自动发现
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档