路由中還能夠引入 html 頁面;
咱們能夠在 route/web.php 中搞定一切了;
可是若是把業務邏輯都寫入到路由中;
那路由將龐大的難以維護;
因而控制器就有了很明顯的存在價值;
把業務邏輯寫在控制器中;
路由只負責轉發請求到指定的控制器便可;php
啥?你要手動建立文件?
no;既然用上了現代話框架;
必須得用有點逼格的方式幹這苦力活了;html
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