1. 程式人生 > >Laravel5.1 -控制器(初步了解)

Laravel5.1 -控制器(初步了解)

remove 喜歡 style 方法 function edit logs ora pla

首先道個歉 這篇筆記是前兩天就應該寫的,可大K有點事兒要忙 就耽誤了,今天抽空學了學控制器,並寫個筆記分享下。

為什麽要使用控制器

像我們之前寫一些邏輯呢都是在Route(路由)中,搞得Route文件特別龐大,其實我們應該把這些邏輯都抽到一個控制器裏,路由分發後到控制器,控制器做相應的操作,比如關於後臺的邏輯應該抽到AdminController中,Route文件只管分發。


1 如何創建一個控制器

1.1.1 創建RESTful控制器

至於什麽是RESTful?自行百度- -,我先簡單說下,它裏面自動填充了一些增刪改查的方法。OK 我們在Artisan控制臺創建:

php artisan make:controller Admin\\HomeController

然後 我們在 app/Http/Controller/Admin/ 下找到它:

class HomeController extends Controller
{
    /**
     * Display a listing of the resource.
     *
     * @return \Illuminate\Http\Response
     */
    public function index()
    {
        
    }

    /**
     * Show the form for creating a new resource.
     *
     * @return \Illuminate\Http\Response
     
*/ public function create() { // } /** * Store a newly created resource in storage. * * @param \Illuminate\Http\Request $request * @return \Illuminate\Http\Response */ public function store(Request $request) { // } /** * Display the specified resource. * * @param int $id * @return \Illuminate\Http\Response
*/ public function show($id) { // } /** * Show the form for editing the specified resource. * * @param int $id * @return \Illuminate\Http\Response */ public function edit($id) { // } /** * Update the specified resource in storage. * * @param \Illuminate\Http\Request $request * @param int $id * @return \Illuminate\Http\Response */ public function update(Request $request, $id) { // } /** * Remove the specified resource from storage. * * @param int $id * @return \Illuminate\Http\Response */ public function destroy($id) { // } }

每個方法就是它的字面意思,至於怎麽使用,我們來註冊一條路由就清楚了。

1.1.2 實現RESTful路由

Route::group([‘prefix‘ => ‘admin‘, ‘namespace‘ => ‘Admin‘], function (){
    Route::resource(‘/‘, ‘HomeController‘);
});

resource是為RESTful風格的控制器註冊多條路由的 我們可以在Artisan控制臺看看:

php artisan route:list

如果沒有什麽錯誤的話,咱肯定會看見打印出來的表,表裏面標明了每條路由的屬性,如果你還是不太明白,那無所謂~咱以後的文章會頻繁使用到這些內容哦。

1.2.1 普通控制器

在實際開發中啊 有時候咱不一定需要RESTful風格的服務器,我們只想要一個空的控制器來自己實現一些方法,可以這麽生成:

php artisan make:controller UserController --plain

只要後面跟個plain標識符 就可以生成空的控制器啦。

1.2.2 單條路由使用控制器

上面是使用resource方法來對應控制器的動作了,像這種空的控制器咱怎麽在路由中使用呢?

/**
 * [email protected] 就可以了
 */
Route::get(‘/user‘, [email protected]);

/**
 * 這是在配置一些其他東西時的寫法,因為要在數組中嘛,它對應的KEY是uses。
 */
Route::get(‘/user‘, [‘as‘ => ‘showUser‘, ‘uses‘ => [email protected]]);

然後自行實現UserController的index方法就可以咯:

class UserController extends Controller
{
    public function index()
    {
        return ‘展示一些東西‘;
    }
}

1.3.1 其實還有另一種寫法 隱式控制器

這種路由我不太常用 先來看看語法吧:

Route::controller(‘/user‘, ‘UserController‘);

首先 使用了controller來註冊路由,第一個參數是路徑沒新鮮的,第二個參數是控制器 但是它沒有跟著方法。因為它能自動根據路徑相應到方法 看看下面控制器方法的實現。

class UserController extends Controller
{
    /**
     * 對應著 /user/ 路由  GET方式
     */
    public function getIndex()
    {
        return ‘展示一些東西~‘;
    }

    /**
     * 對應著 /user/show/{id} 路由  GET方式
     */
    public function getShow($id)
    {
        return ‘此用戶ID為: ‘.$id;
    }

    /**
     * 對應著 /user/update/{id} 路由  POST方式
     */
    public function postUpdate($id, Requests\Request $request){

    }
}

這個控制器的方法開頭都是HTTP請求的方式 最常用的就是GET 和 POST 後面跟的是方法名字,具體對應的路徑在註釋中寫清楚了。

如果你想給這些路由命名的話,後面可以跟一個數組來命名:

Route::controller(‘/user‘, ‘UserController‘,[‘getShow‘ => ‘user.show‘]);

這樣就可以給對應的方法命名了,oh funk 大K真的不喜歡這種方式,也許是沒明白這樣寫的真諦把。

--今天關於控制器就先寫這麽多吧,具體邏輯實現咱還得學一些新的知識來結合使用,比如middleware啊和request還有blade模板引擎,但都不是很難~

Laravel5.1 -控制器(初步了解)