最適合入門的 Laravel 入門教程 (四)

白俊遙發表於2018-01-09

路由可以分發請求;
路由中還可以引入 html 頁面;
我們可以在 route/web.php 中搞定一切了;
但是如果把業務邏輯都寫入到路由中;
那路由將龐大的難以維護;
於是控制器就有了很明顯的存在價值;
把業務邏輯寫在控制器中;
路由只負責轉發請求到指定的控制器即可;

ok;那我們開始建立控制器;
啥?你要手動建立檔案?
no;既然用上了現代話框架;
必須得用有點逼格的方式幹這苦力活了;

好了;下面插播一段 artisan 的內容;
laravel 是一個現代話框架;
它對命令列有著非常好的支援;
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

相關文章