聊聊laravel中資源路由的使用方法

laravel作為一種主流的web應用程序開發框架,可以幫助開發人員快速高效地創建web應用程序。其中,資源路由(Resource routes)是laravel框架中的一個非常有用的功能,它可以幫助開發人員輕松地定義項目中所需的url路由,降低了開發難度,并簡化了代碼實現。在本文中,我們將研究laravel資源路由的使用方法,幫助開發人員了解它的工作原理,以及如何在項目中使用它。

一、什么是Laravel資源路由(Resource Routes)?

在Laravel框架中,資源路由(Resource Routes)是一種特殊的路由類型,它允許開發人員將URL路由和控制器方法綁定在一起,這樣開發人員就可以很方便地創建CRUD(Create, Read, Update, delete)操作了。

在使用資源路由時,開發人員只需要在routes/web.php文件中定義一個路由,Laravel就會為該路由自動生成7個基本的CRUD操作方法,以及適當的路由名稱。這極大地簡化了代碼實現,減少了開發難度。總之,使用Laravel資源路由可以大大提高開發效率。

二、資源路由的基本語法

Laravel資源路由的基本語法如下所示:

Route::resource('resource_name', 'ResourceController');

其中,’resource_name’代表資源名稱,’ResourceController’代表控制器名稱。

Laravel會基于這個資源名稱自動生成7個restful路由,它們分別對應于7個基本的CRUD操作,如下所示:

方法 URI 操作 名稱
GET /resource_name index resource_name.index
GET /resource_name/create create resource_name.create
POST /resource_name store resource_name.store
GET /resource_name/{resource_name} show resource_name.show
GET /resource_name/{resource_name}/edit edit resource_name.edit
PUT/PATCH /resource_name/{resource_name} update resource_name.update
DELETE /resource_name/{resource_name} destroy resource_name.destroy

至此,我們了解了Laravel資源路由的基本語法和7個基本的RESTful路由。但是,有時候在項目中,我們需要自定義路由名稱,或者修改路由方法。下面,我們將詳細講解如何自定義Laravel資源路由。

三、自定義Laravel資源路由

在Laravel中,我們可以通過修改資源參數來自定義資源路由。下面,我們以’articles’為例,介紹自定義Laravel資源路由的三種方法。

  1. 自定義路由名稱

如果我們不想使用Laravel默認的路由名稱,可以使用’as’命令來自定義路由名稱。如下所示:

Route::resource('articles', 'ArticleController', ['names' => [     'create' => 'articles.build',     'edit' => 'articles.modify' ]]);

這里,我們定義了自定義路由名稱’articles.build’和’articles.modify’,它們分別對應于”articles/create”和”articles/{id}/edit”這兩條路由。

  1. 自定義路由方法

除了自定義路由名稱外,我們還可以通過修改資源參數來自定義路由方法。如下所示:

Route::resource('articles', 'ArticleController', ['only' => [     'index', 'show' ]]);

這里,我們只定義了’index’和’show’這兩個路由方法,因此’Laravel’會生成對應的’GET /articles’和’GET articles/{id}’兩個路由,并且隱藏默認的路由名稱。

  1. 自定義資源參數

如果我們不想使用’Laravel’默認的資源參數’id’,可以使用’parameters’命令來自定義資源參數。如下所示:

Route::resource('articles', 'ArticleController', ['parameters' => [     'articles' => 'post' ]]);

這里,我們將資源名稱’articles’修改為’post’,這樣’Laravel’會接收到類似于’POST /post’這種請求,并將’id’參數綁定到控制器方法中。

四、Laravel資源路由實戰

在本節中,我們將使用Laravel資源路由來創建一個簡單的在線筆記應用程序。首先,在routes/web.php文件中定義資源路由,如下所示:

Route::resource('notes', 'NoteController');

接下來,我們創建一個NoteController,定義資源路由中7個基本的RESTful路由的實現方法。如下所示:

class NoteController extends Controller {     // 獲取筆記列表     public function index()     {         // 獲取所有筆記記錄         $notes = Note::all();          // 返回筆記記錄列表視圖         return view('notes.index', compact('notes'));     }      // 顯示筆記創建視圖     public function create()     {         // 返回筆記創建視圖         return view('notes.create');     }      // 創建新筆記     public function store(Request $request)     {         // 數據驗證         $request->validate([             'title' => 'required|max:255',             'content' => 'required',         ]);          // 創建新筆記并保存到數據庫         $note = new Note();         $note->title = $request->input('title');         $note->content = $request->input('content');         $note->save();          // 重定向到筆記列表頁面         return redirect('/notes');     }      // 獲取指定筆記詳情     public function show(Note $note)     {         // 返回指定筆記記錄視圖         return view('notes.show', compact('note'));     }      // 顯示筆記編輯視圖     public function edit(Note $note)     {         // 返回筆記編輯視圖         return view('notes.edit', compact('note'));     }      // 更新指定筆記     public function update(Request $request, Note $note)     {         // 數據驗證         $request->validate([             'title' => 'required|max:255',             'content' => 'required',         ]);          // 更新指定筆記并保存到數據庫         $note->title = $request->input('title');         $note->content = $request->input('content');         $note->save();          // 重定向到筆記列表頁面         return redirect('/notes');     }      // 刪除指定筆記     public function destroy(Note $note)     {         // 刪除指定筆記記錄         $note->delete();          // 重定向到筆記列表頁面         return redirect('/notes');     } }

在NoteController中,我們實現了7個基本的CRUD操作方法,分別對應于7個資源路由。其中,我們使用了Laravel自帶的表單驗證來驗證用戶輸入的數據,以確保數據的準確性和完整性。

最后,在resources/views目錄中創建7個視圖文件,對應于7個基本的CRUD操作。如下所示:

  1. resources/views/notes/index.blade.php:
@extends('layouts.app')  @section('content')     <div class="container">         <div class="row">             <div class="col-md-12">                 <h1>Laravel Resource Route Demo</h1>                 <hr>                 <h2>Note List:</h2>                 <ul>                     @foreach($notes as $note)                         <li><a href="/notes/{{$note->id}}">{{$note->title}}</a></li>                     @endforeach                 </ul>             </div>         </div>     </div> @endsection
  1. resources/views/notes/create.blade.php:
@extends('layouts.app')  @section('content')     <div class="container">         <div class="row">             <div class="col-md-12">                 <h1>New Note:</h1>                 <hr>                 <form method="post" action="/notes">                     {{csrf_field()}}                     <div class="form-group">                         <label for="title">Title</label>                         <input type="text" class="form-control" name="title" id="title" placeholder="Enter the title">                     </div>                     <div class="form-group">                         <label for="content">Content</label>                         <textarea class="form-control" name="content" id="content" placeholder="Enter the content"></textarea>                     </div>                     <button type="submit" class="btn btn-primary">Submit</button>                 </form>             </div>         </div>     </div> @endsection
  1. resources/views/notes/show.blade.php:
@extends('layouts.app')  @section('content')     <div class="container">         <div class="row">             <div class="col-md-12">                 <h1>Note Detail:</h1>                 <hr>                 <h2>Title:</h2>                 <p>{{$note->title}}</p>                 <h2>Content:</h2>                 <p>{{$note->content}}</p>                 <a href="/notes/{{$note->id}}/edit" class="btn btn-primary">Edit</a>                 <form method="post" action="/notes/{{$note->id}}" style="display: inline-block;">                     {{csrf_field()}}                     {{method_field('DELETE')}}                     <button type="submit" class="btn btn-danger">Delete</button>                 </form>             </div>         </div>     </div> @endsection
  1. resources/views/notes/edit.blade.php:
@extends('layouts.app')  @section('content')     <div class="container">         <div class="row">             <div class="col-md-12">                 <h1>Edit Note:</h1>                 <hr>                 <form method="post" action="/notes/{{$note->id}}">                     {{csrf_field()}}                     {{method_field('PUT')}}                     <div class="form-group">                         <label for="title">Title</label>                         <input type="text" class="form-control" name="title" id="title" value="{{$note->title}}">                     </div>                     <div class="form-group">                         <label for="content">Content</label>                         <textarea class="form-control" name="content" id="content">{{$note->content}}</textarea>                     </div>                     <button type="submit" class="btn btn-primary">Update</button>                 </form>             </div>         </div>     </div> @endsection

上面這四個視圖文件分別對應于顯示筆記列表、顯示創建筆記表單、顯示筆記詳細信息和編輯筆記功能。

最后,我們運行服務器并訪問http://localhost:8000/notes即可看到演示效果。

總結

本文我們介紹了Laravel資源路由的基本用法和語法規則。我們從什么是Laravel資源路由開始,深入到如何使用Laravel資源路由創建CRUD工具,以及如何自定義Laravel資源路由。最后,通過筆記應用程序的演示,加深了對于Laravel資源路由的理解。現在,你掌握了使用Laravel資源路由構建高效Web應用程序的核心知識,可以應用到實際項目中了。

? 版權聲明
THE END
喜歡就支持一下吧
點贊13 分享