1. 程式人生 > 程式設計 >Laravel5.1 框架控制器基礎用法例項分析

Laravel5.1 框架控制器基礎用法例項分析

本文例項講述了Laravel5.1 框架控制器基礎用法。分享給大家供大家參考,具體如下:

為什麼要使用控制器

像我們之前寫一些邏輯呢都是在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方法來對應控制器的動作了,像這種空的控制器咱怎麼在路由中使用呢?

/**
 * 控制器名@方法名 就可以了
 */
Route::get('/user','UserController@index');
/**
 * 這是在配置一些其他東西時的寫法,因為要在陣列中嘛,它對應的KEY是uses。
 */
Route::get('/user',['as' => 'showUser','uses' => 'UserController@index']);

然後自行實現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模板引擎,但都不是很難~

更多關於Laravel相關內容感興趣的讀者可檢視本站專題:《Laravel框架入門與進階教程》、《php優秀開發框架總結》、《php面向物件程式設計入門教程》、《php+mysql資料庫操作入門教程》及《php常見資料庫操作技巧彙總》

希望本文所述對大家基於Laravel框架的PHP程式設計有所幫助。