如何在Laravel之外使用illuminate組件詳解
當(dāng)代框架基本都是有組件構(gòu)成,這使得框架變得更加靈活。The Laravel Components | github Laravel 中有不少優(yōu)質(zhì)組件,那如何在 Laravel 之外使用 illuminate 組件呢?
illuminate/validation
以 illuminate/validation 為例,validation 有豐富的數(shù)據(jù)驗(yàn)證功能。
在項(xiàng)目的 composer.json 文件中添加:
... "require": { ... "illuminate/validation": "^5.8", ...
從 Laravel-Lang/lang 項(xiàng)目中復(fù)制需要的語言文件放到自己的項(xiàng)目中。
例如:在 Yii2 項(xiàng)目中,復(fù)制對應(yīng)語言文件到項(xiàng)目中的 assets/lang/zh-CN/validation.php。
創(chuàng)建 common/Validator.php:
namespace app\common; use Illuminate\Filesystem\Filesystem; use Illuminate\Translation\FileLoader; use Illuminate\Translation\Translator; use Illuminate\Validation\Factory; class Validator { private static $instance = null; private function __construct() { } public static function getInstance(): Factory { if (null === static::$instance) { $translationPath = get_alias('@assets/lang'); $translationLocale = 'zh-CN'; $transFileLoader = new FileLoader(new Filesystem(), $translationPath); $translator = new Translator($transFileLoader, $translationLocale); static::$instance = new Factory($translator); } return static::$instance; } }
在全局函數(shù)文件添加:
// https://learnku.com/docs/laravel/5.8/validation/3899#manually-creating-validators // $rules = [ // 'name' => 'required|string|min:2|max:5', // 'code' => 'required|string|min:2|max:5', // ]; function validator(array $data, array $rules, array $messages = [], array $customAttributes = []) { return \app\common\Validator::getInstance()->make($data, $rules, $messages, $customAttributes); }
測試使用:
$rules = ['name' => 'required|numeric']; $customAttributes = ['name' => 'My name']; $messages = ['name.required' => 'A name is required',]; $validator = validator($data, $rules, $customAttributes, $messages); if ($validator->fails()) { $errors = $validator->errors()->all(); Response::error(Errors::ParamsInvalid, implode(',', $errors), $errors); }
總結(jié)
到此這篇關(guān)于如何在Laravel之外使用illuminate組件的文章就介紹到這了,更多相關(guān)Laravel之外使用illuminate組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- umi插件開發(fā)仿dumi項(xiàng)目自動(dòng)生成導(dǎo)航欄實(shí)現(xiàn)詳解
- umi插件開發(fā)仿dumi項(xiàng)目加載markdown文件實(shí)現(xiàn)詳解
- umi插件開發(fā)仿dumi項(xiàng)目實(shí)現(xiàn)markdown文件轉(zhuǎn)為頁面
- 獨(dú)立使用umi的核心插件模塊示例詳解
- JavaScript @umijs/plugin-locale插件使用教程
- Umi4集成阿里低代碼框架lowcode-engine實(shí)現(xiàn)
- umi插件開發(fā)仿dumi項(xiàng)目實(shí)現(xiàn)頁面布局詳解
相關(guān)文章
ThinkPHP分組下自定義標(biāo)簽庫實(shí)例
這篇文章主要介紹了ThinkPHP分組下自定義標(biāo)簽庫的方法,以實(shí)例形式講述了自定義標(biāo)簽庫的具體步驟,非常具有參考借鑒價(jià)值,需要的朋友可以參考下2014-11-11Thinkphp 框架擴(kuò)展之驅(qū)動(dòng)擴(kuò)展實(shí)例分析
這篇文章主要介紹了Thinkphp 框架擴(kuò)展之驅(qū)動(dòng)擴(kuò)展,結(jié)合實(shí)例形式分析了Thinkphp 框架驅(qū)動(dòng)擴(kuò)展相關(guān)原理、實(shí)現(xiàn)方法及操作注意事項(xiàng),需要的朋友可以參考下2020-04-04使用PHP進(jìn)行微信公眾平臺(tái)開發(fā)的示例
這篇文章主要介紹了使用PHP進(jìn)行微信公眾平臺(tái)開發(fā)的示例,包括基本的微信平臺(tái)API調(diào)用和XML處理等,需要的朋友可以參考下2015-08-08Laravel 5.4因特殊字段太長導(dǎo)致migrations報(bào)錯(cuò)的解決
這篇文章主要給大家介紹了關(guān)于Laravel 5.4因特殊字段太長導(dǎo)致migrations報(bào)錯(cuò)的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起看看吧。2017-10-10php 提交表單 關(guān)閉layer彈窗iframe的實(shí)例講解
今天小編就為大家分享一篇php 提交表單 關(guān)閉layer彈窗iframe的實(shí)例講解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08php數(shù)組查找函數(shù)in_array()、array_search()、array_key_exists()使用實(shí)例
這篇文章主要介紹了php數(shù)組查找函數(shù)in_array()、array_search()、array_key_exists()使用實(shí)例,需要的朋友可以參考下2014-04-04laravel Task Scheduling(任務(wù)調(diào)度)在windows下的使用詳解
今天小編就為大家分享一篇laravel Task Scheduling(任務(wù)調(diào)度)在windows下的使用詳解,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10ThinkPHP3.2.3實(shí)現(xiàn)分頁的方法詳解
這篇文章主要介紹了ThinkPHP3.2.3實(shí)現(xiàn)分頁的方法,詳細(xì)分析了thinkPHP3.2.3分頁操作的相關(guān)技巧,包括分頁類的引用、數(shù)據(jù)庫查詢操作、分頁參數(shù)設(shè)置及前端視圖界面設(shè)計(jì)等,需要的朋友可以參考下2016-06-06