首先讓我們修改路由,能夠增加一個文章的發布。
<code>Route::get('articles/create', 'ArticlesController@create');</code>
然後修改控制器
<code> public function create() { return view('articles.create'); }</code>
我們回傳一個視圖,新建這個視圖。我們當然可以直接使用HTML建立表單,但我們有功能更好的方法。我們使用一個開源函式庫,Jeffrey Way 開發的illuminatehtml。安裝相依性庫:
<code>composer require illuminate/html</code>
laravel的庫需要註冊到laravel才能使用。在 config/app.php
中,我們可以看到 laravel 提供的 provider
字段,這裡描述了laravel的庫功能。在Laravel Framewirk Service Providers...
最後加入我們新增的 HtmlProvider
<code>'Illuminate\Html\HtmlServiceProvider',</code>
我們不希望使用 IlluminateHtmlFromFacade
這麼長的名字來引入,我們需要簡短的名字。在目前的 app.php
找到 aliases 段,最後加上別名。
<code>'Form' => 'Illuminate\Html\FormFacade', 'Html' => 'Illuminate\Html\HtmlFacade',</code>
OK,現在我們來建立視圖,views/articles/create.blade.php
<code>@extends('layout') @section('content') <h1 id="Write-a-New-Article">Write a New Article</h1> <hr> {{--使用我们添加的 illuminate\html 开源库--}} {!! Form::open() !!} {!! Form::close() !!} @stop</code>
訪問 /articles/create
看到了錯誤,Why? 讓我們測試一下,到底是哪裡出了問題。在控制器中做出下面的修改:
<code> public function show($id) { dd('show'); $article = Article::findOrFail($id); return view('articles.show', compact('article')); }</code>
沒錯,你沒看錯,就是在 show
方法中加入 dd()
方法,這個方法簡單的輸出一個訊息然後死掉。我們再來訪問 /articles/create
,你看到了什麼,你看到輸出了 show
。
為什麼我們訪問 create
結果路由給了我們 show
? 我們來查看一下路由,到底發生了什麼。
<code>Route::get('articles', 'ArticlesController@index'); Route::get('articles/{id}', 'ArticlesController@show'); Route::get('articles/create', 'ArticlesController@create');</code>
上面是我們的路由,注意到 articles/{id}
意味著這是一個通配符,所有在 articles/
後面的東西都會匹配,你知道了什麼?我們的 /articles/create
也被他配對了。 OMG!
解決方案就是調整順序:
<code>Route::get('articles', 'ArticlesController@index'); Route::get('articles/create', 'ArticlesController@create'); Route::get('articles/{id}', 'ArticlesController@show');</code>
也就是從特殊到普通,以後的路由設定要時時注意這個問題。現在我們在訪問 articles/create
一切OK了。
在瀏覽器中查看一下原始程式碼,你會發現不僅產生了 method
和 action
同時產生了一個隱藏的 _token
欄位作為伺服器對窗體的驗證,避免駭客的偽造攻擊。
讓我們修改我們的視圖,新增欄位:
<code>@extends('layout') @section('content') <h1 id="Write-a-New-Article">Write a New Article</h1> <hr> {{--使用我们添加的 illuminate\html 开源库--}} {!! Form::open() !!} <div class="form-group"> {!! Form::label('title', 'Title:') !!} {!! Form::text('title', null, ['class' => 'form-control']) !!} </div> <div class="form-group"> {!! Form::label('body', 'Body:') !!} {!! Form::textarea('body', null, ['class' => 'form-control']) !!} </div> <div class="form-group"> {!! Form::submit('Add Article', ['class' => 'btn btn-primary form-control']) !!} </div> {!! Form::close() !!} @stop</code>
當表單提交的時候,實際上是使用post
方法提交到articles/create
上的,但根據RESTful的習慣,我們希望能夠post
到/articles
上,我們來修改視圖的表單方法,設定提交的路徑。
<code>{!! Form::open(['url' => 'articles']) !!}</code>
然後我們在路由中處理表單提交事件。
<code>Route::post('/articles', 'ArticlesController@store');</code>
我們來處理控制器
<code> //注意:将下面的 use 语句删除,我们使用 facade 接口中的 Request //use App\Http\Requests\Request; //引入下面的命名空间中的 Request use Illuminate\Support\Facades\Request; public function store() { //使用 Illuminate\Html\Request 来返回全部的表单输入字段 $input = Request::all(); //我们直接返回$input,来看一下 return $input; }</code>
我們可以直接看到輸入表單的json結果。如果只需要 title
欄位的值,則可以使用 Request::get('titel')
。
如何加入資料庫呢?借助模型,我們可以直接採用下面的方法,
<code>Article::create($input);</code>
就這麼簡單,就是這麼任性
如果沒有忘記 Mass Assignment,在我們的模型中我們定義了 $fillable
數組,來定義那些字段可以直接在 create
的時候直接填充。
修改控制器,加入到模型中,並儲存到資料庫。
<code> public function store() { $input = Request::all(); Article::create($input); return redirect('articles'); }</code>
新增一筆記錄試試,非常棒。但別忘了。我們還有一個欄位叫做 published_at
,讓我們來處理它。
<code> public function store() { $input = Request::all(); $input['published_at'] = Carbon::now(); Article::create($input); return redirect('articles'); }</code>
添加新紀錄在測試一下。
還有一個問題,新加入的應該顯示在最前面,我們來修改以下控制器。
<code> public function index() { //倒序获取文章 //可以这样 //$articles = Article::orderBy('published_at', 'desc')->get(); //简单方式,当然还有 oldest() $articles = Article::latest('published_at')->get(); return view('articles.index', compact('articles')); }</code>
以上就介紹了Laravel 5 基礎(九)- 表單,包括了方面的內容,希望對PHP教程有興趣的朋友有所幫助。

PHP仍然流行的原因是其易用性、靈活性和強大的生態系統。 1)易用性和簡單語法使其成為初學者的首選。 2)與web開發緊密結合,處理HTTP請求和數據庫交互出色。 3)龐大的生態系統提供了豐富的工具和庫。 4)活躍的社區和開源性質使其適應新需求和技術趨勢。

PHP和Python都是高層次的編程語言,廣泛應用於Web開發、數據處理和自動化任務。 1.PHP常用於構建動態網站和內容管理系統,而Python常用於構建Web框架和數據科學。 2.PHP使用echo輸出內容,Python使用print。 3.兩者都支持面向對象編程,但語法和關鍵字不同。 4.PHP支持弱類型轉換,Python則更嚴格。 5.PHP性能優化包括使用OPcache和異步編程,Python則使用cProfile和異步編程。

PHP主要是過程式編程,但也支持面向對象編程(OOP);Python支持多種範式,包括OOP、函數式和過程式編程。 PHP適合web開發,Python適用於多種應用,如數據分析和機器學習。

PHP起源於1994年,由RasmusLerdorf開發,最初用於跟踪網站訪問者,逐漸演變為服務器端腳本語言,廣泛應用於網頁開發。 Python由GuidovanRossum於1980年代末開發,1991年首次發布,強調代碼可讀性和簡潔性,適用於科學計算、數據分析等領域。

PHP適合網頁開發和快速原型開發,Python適用於數據科學和機器學習。 1.PHP用於動態網頁開發,語法簡單,適合快速開發。 2.Python語法簡潔,適用於多領域,庫生態系統強大。

PHP在現代化進程中仍然重要,因為它支持大量網站和應用,並通過框架適應開發需求。 1.PHP7提升了性能並引入了新功能。 2.現代框架如Laravel、Symfony和CodeIgniter簡化開發,提高代碼質量。 3.性能優化和最佳實踐進一步提升應用效率。

PHPhassignificantlyimpactedwebdevelopmentandextendsbeyondit.1)ItpowersmajorplatformslikeWordPressandexcelsindatabaseinteractions.2)PHP'sadaptabilityallowsittoscaleforlargeapplicationsusingframeworkslikeLaravel.3)Beyondweb,PHPisusedincommand-linescrip

PHP類型提示提升代碼質量和可讀性。 1)標量類型提示:自PHP7.0起,允許在函數參數中指定基本數據類型,如int、float等。 2)返回類型提示:確保函數返回值類型的一致性。 3)聯合類型提示:自PHP8.0起,允許在函數參數或返回值中指定多個類型。 4)可空類型提示:允許包含null值,處理可能返回空值的函數。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

Dreamweaver Mac版
視覺化網頁開發工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。