路由可以分發請求;
路由中還可以引入 html 頁面;
我們可以在 route/web.php 中搞定一切了;
但是如果把業務邏輯都寫入到路由中;
那路由將龐大的難以維護;
於是控制器就有了很明顯的存在價值;
把業務邏輯寫在控制器中;
路由只負責轉發請求到指定的控制器即可;
ok;那我們開始建立控制器;
啥?你要手動建立檔案?
no;既然用上了現代話框架;
必須得用有點逼格的方式幹這苦力活了;
好了;下面插播一段 artisan
的內容;
laravel 是一個現代話框架;
它對命令列有著非常好的支援;
artisan 就是 laravel 的命令列介面;
就是根目錄下的 artisan 檔案;
我們可以把它理解為命令列級的單入口檔案;
跟 index.php 檔案的使命一樣;
所有的命令列都從它這走;
所以如果想使用命令列;
就需要 cd 到專案的根目錄下;
或者手動指定一長串路徑;
啥?還有人問什麼 cd ?
好吧;還好我有掃盲文章 插播一篇windows下git bash命令列使用的文章
起手式就是 php artisan
;
在命令列中以 php 開頭意思是用 php 來執行某個檔案;php index.php
意思就是使用 php 的命令列模式執行 index.php ;
命令列下是可以不需要檔案字尾就能識別的;
所以根目錄下的 artisan 檔案並沒有帶上 .php ;
命令列主要有兩個方向的應用;
第一是生成檔案;
第二是執行任務;
我們馬上就要用它生成控制器檔案;
php artisan make:controller ArticleController
如果人品正常;
那麼會生成一個 app/Http/Controllers/ArticleController.php 檔案;
開啟是這個樣子的;
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
class ArticleController extends Controller
{
//
}
不但自動建立了檔案;
而且還定義好了名稱空間;
繼承好了父級控制器;
我們直接寫增刪改查的方法就可以了;
ok;說幹就幹吧;
啥?你要手動寫方法?
no;既然用上了現代話框架;
必須得用有點逼格的方式幹這苦力活了;
來給上面的命令列加個--resource
選項;
php artisan make:controller ArticleController --resource
如果直接執行的話是會報錯的;
提示 Controller already exists!
;
因為我們剛已經建立過 ArticleController了;
所以我們需要先把 app/Http/Controllers/ArticleController.php 檔案刪掉再執行;
如果人品正常;
那麼會再次生成一個 app/Http/Controllers/ArticleController.php 檔案;
開啟是這個樣子的;
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
class ArticleController 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)
{
//
}
}
怎麼樣?
驚不驚喜?
開不開心?
有木有被驚die了
不但增刪改查的方法都定義好了;
連註釋都給寫好了;
這其實是按 RESTful 規範生成的格式;
除了 GET POST 它還包含了一大堆請求方式;
PUT 、 PATCH 、 DELETE 、HEAD 、OPTIONS;
也就是說 Route:: 後面還可以跟上面這些方法;
Route::put('article', function () {
return view('article');
});
// ...
RESTful 是本篇文章的一個擴充套件題;
童鞋們可以搜尋瞭解下;
如果被概念搞的有點懵;
沒關係;
留給以後慢慢搞;
現在我們只用 GET POST 足夠學習了;
ok;我們開始在方法中寫業務邏輯吧;
啥?你要手動寫程式碼?
廢話;不然用腳動寫?
別看了;
下面沒驚喜了;
本文為白俊遙原創文章,轉載無需和我聯絡,但請註明來自白俊遙部落格 https://baijunyao.com