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

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

路由能夠分發請求;

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

ok;那咱們開始建立控制器;

啥?你要手動建立文件?
no;既然用上了現代話框架;
必須得用有點逼格的方式幹這苦力活了;html

好了;下面插播一段 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 ;laravel

命令行主要有兩個方向的應用;

第一是生成文件;
第二是執行任務;
咱們立刻就要用它生成控制器文件;git

php artisan make:controller ArticleController

若是人品正常;
那麼會生成一個 app/Http/Controllers/ArticleController.php 文件;
打開是這個樣子的;web

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;

class ArticleController extends Controller
{
    //
}

不但自動建立了文件;
並且還定義好了命名空間;
繼承好了父級控制器;
咱們直接寫增刪改查的方法就能夠了;windows

ok;說幹就幹吧;
啥?你要手動寫方法?
no;既然用上了現代話框架;
必須得用有點逼格的方式幹這苦力活了;
來給上面的命令行加個--resource選項;bash

php artisan make:controller ArticleController --resource

若是直接運行的話是會報錯的;
提示 Controller already exists!
由於咱們剛已經建立過 ArticleController了;
因此咱們須要先把 app/Http/Controllers/ArticleController.php 文件刪掉再運行;
若是人品正常;
那麼會再次生成一個 app/Http/Controllers/ArticleController.php 文件;
打開是這個樣子的;app

<?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

相關文章
相關標籤/搜索