为了避免进行危险性的操作,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 向 rules 方法提供规则:
// Using an array...
Text::make('State')->rules(['required', new ValidState]),
// Using a Closure...
Text::make('State')->rules(fn ($request) => [
'required',
new ValidState(),
]);当然,你也可以使用 自定义 Closure 验证规则 来验证资源字段:
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}}'),Nova 还提供了几种方法,允许你在资源验证后执行任务,从而有机会在资源持久化到数据库之前执行更多自定义验证:
afterValidation 方法 资源在创建或更新过程中经过验证后,将始终调用 afterValidation 方法。该方法将在调用 afterCreationValidation 或 afterUpdateValidation 之前被调用:
/**
* 处理任何验证后处理
*
* @param \Laravel\Nova\Http\Requests\NovaRequest $request
* @param \Illuminate\Validation\Validator $validator
* @return void
*/
protected static function afterValidation(NovaRequest $request, $validator)
{
if (self::somethingElseIsInvalid()) {
$validator->errors()->add('field', 'Something is wrong with this field!');
}
}afterCreationValidation 方法 afterCreationValidation 方法将在创建的资源通过验证后调用:
/**
* 处理任何创建后的验证处理。
*
* @param \Laravel\Nova\Http\Requests\NovaRequest $request
* @param \Illuminate\Validation\Validator $validator
* @return void
*/
protected static function afterCreationValidation(NovaRequest $request, $validator)
{
if (self::somethingElseIsInvalid()) {
$validator->errors()->add('field', 'Something is wrong with this field!');
}
}afterUpdateValidation 方法 afterUpdateValidation 方法将在更新的资源通过验证后调用:
/**
* 处理任何更新后的验证处理。
*
* @param \Laravel\Nova\Http\Requests\NovaRequest $request
* @param \Illuminate\Validation\Validator $validator
* @return void
*/
protected static function afterUpdateValidation(NovaRequest $request, $validator)
{
if (self::somethingElseIsInvalid()) {
$validator->errors()->add('field', 'Something is wrong with this field!');
}
}