验证

未匹配的标注

为了避免进行危险性的操作, Nova 在创建 / 更新屏幕上显示的任何 Nova 字段都需要进行一些验证。值得庆幸的是,将你所熟悉的 Laravel 验证规则附加到 Nova 资源字段中非常简单。下面让我们看看它是怎么使用的。

附加规则

在资源上定义字段时,你可以使用 rules 方法将 验证规则 附加到字段:

Text::make('Name')
    ->sortable()
    ->rules('required', 'max:255'),

当然,如果你正在使用 Laravel 的 验证规则对象, 你也可以将这些对象附加到资源当中:

use App\Rules\ValidState;

Text::make('State')
    ->sortable()
    ->rules('required', new ValidState),

当然, 你也可以使用 自定义 Closure 验证规则 来验证资源字段:

use App\Rules\ValidState;

Text::make('State')
    ->sortable()
    ->rules('required', function($attribute, $value, $fail) {
        if (strtoupper($value) !== $value) {
            return $fail('The '.$attribute.' field must be uppercase.');
        }
    })

添加规则

如果要定义仅在创建资源时应用的规则,可以使用以下 creationRules 方法:

Text::make('Email')
    ->sortable()
    ->rules('required', 'email', 'max:255')
    ->creationRules('unique:users,email')
    ->updateRules('unique:users,email,{{resourceId}}'),

更新规则

同样,如果要定义仅在更新资源时应用的验证规则,则可以使用 updateRules 方法。如有必要,你可以在规则定义中使用占位符 resourceId。此占位符将自动替换为正在更新的资源的主键:

Text::make('Email')
    ->sortable()
    ->rules('required', 'email', 'max:255')
    ->creationRules('unique:users,email')
    ->updateRules('unique:users,email,{{resourceId}}'),

本文章首发在 LearnKu.com 网站上。

本译文仅用于学习和交流目的,转载请务必注明文章译者、出处、和本文链接
我们的翻译工作遵照 CC 协议,如果我们的工作有侵犯到您的权益,请及时联系我们。

原文地址:https://learnku.com/docs/nova/1.0/verifi...

译文地址:https://learnku.com/docs/nova/1.0/verifi...

上一篇 下一篇
《L05 电商实战》
从零开发一个电商项目,功能包括电商后台、商品 & SKU 管理、购物车、订单管理、支付宝支付、微信支付、订单退款流程、优惠券等
《L04 微信小程序从零到发布》
从小程序个人账户申请开始,带你一步步进行开发一个微信小程序,直到提交微信控制台上线发布。
贡献者:2
讨论数量: 0
发起讨论 查看所有版本


暂无话题~