您好,登錄后才能下訂單哦!
Laravel 5.5 中怎么自定義驗證對象,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
Laravel 5.5 將提供一個全新的自定義驗證規則的對象,以作為原來的 Validator::extend 方法的替代。很多時候我們會直接用正則表達式來處理這種特殊的驗證,也有時候我們會選擇用 Validator::extend 來擴展一個自定義的規則。但在 Laravel 5.5 版本中,我們有了新的手段,只要定義一個實現 Illuminate\Contracts\Validation\Rule 接口的類即可實現自定義的驗證規則,并可以直接使用。
下面是一個簡單的示例:
use Illuminate\Contracts\Validation\Rule; class IsOddValidationRule implements Rule { public function passes($attributes, $value) { return ($value % 2 !== 0); } public function message() { return ':attribute 必須是奇數'; } }
以上代碼定義了一個 IsOddValidationRule 的自定義驗證類,在 Controller 中要使用這個驗證類的話,可以這樣寫:
public function handlForm(Request $request) { $this->validate($request, [ 'oddField' => [new IsOddValidationRule] ]); }
同樣的效果,也可以通過匿名函數(閉包函數)來實現:
public function handleForm(Request $request) { $this->validate($request, [ 'oddField' => [function($attributes, $value, $fail) { if ($value % 2 === 0) { $fail(':attribute 必須是奇數!'); } }] ]); }
在驗證的表單項為空值或者不存在的時候,對應的自定義驗證規則不會執行。這個與系統自帶的驗證規則的邏輯是一致的。如果你希望你的自定義驗證規則,即使是在對應的表單項為空值時也被執行的話,那么只要把繼承的接口從 rule 改成 ImplicitRule 即可:
class IsOddValidationRule implements ImplicitRule { ... }
采用 Laravel 5.5 新增的自定義驗證類,可以更好地管理大量的自定義驗證規則,而且在 PHPStorm 之類的 IDE 中,從驗證代碼里快速跳轉到對應的驗證類的代碼也會更方便。畢竟采用 Validator::extend 的話,你只能通過搜索對應驗證類名稱的字符串來找到規則定義的源代碼。
匿名函數的自定義驗證規則在一次性的簡單驗證邏輯中用起來確實會很方便,或者是在編碼過程中快速測試驗證邏輯也很實用。但是總的來說,還是建議采用更具組織性和可讀性的自定義驗證類。最佳方法是在編寫 Controller 的過程中用匿名函數快速驗證自定義規則,然后再把它移到自定義的驗證類對象中。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。