Laravel 5 基础(九)- 表单
首先让我们修改路由,能够增加一个文章的发布。
<code>Route::get('articles/create', 'ArticlesController@create');</code>
然后修改控制器
<code> public function create() { return view('articles.create'); }</code>
我们返回一个视图,新建这个视图。我们当然可以直接使用HTML建立表单,但我们有功能更好的办法。我们使用一个开源库,Jeffrey Way 开发的illuminate\html。安装依赖库:
<code>composer require illuminate/html</code>
laravel的库需要注册到laravel中才能使用。在 config/app.php
中,我们可以看到 laravel 提供的 provider
字段,这里描述了laravel的库功能。在Laravel Framewirk Service Providers...
最后添加我们新增的 HtmlProvider
<code>'Illuminate\Html\HtmlServiceProvider',</code>
我们不希望使用 Illuminate\Html\FromFacade
这么长的名字来引入,我们需要简短的名字。在当前的 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教程有兴趣的朋友有所帮助。

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Perubahan nama token Binaryx: Dari BNX hingga empat, dan kemudian membentuk, makna yang mendalam di sebalik pelarasan strategik Binaryx baru -baru ini mengubah simbol token dari $ empat hingga $ bentuk, yang telah menarik perhatian yang meluas dari industri. Ini bukan kali pertama Binaryx telah menukar namanya, dan simbol tokennya telah menjalani peralihan dari BNX ke empat. Artikel ini akan meneroka niat strategik yang mendalam di sebalik siri perubahan nama ini. 1. Proses perubahan nama token dan pertimbangan strategik BinaryX pada mulanya melancarkan token $ BNX berdasarkan rantaian BNB pada tahun 2021 untuk menyokong ekosistem permainan Play-to-Earn (P2E). Pada awal tahun 2024, untuk mengoptimumkan model ekonomi, BinaryX membahagikan $ bnx dan secara beransur -ansur berkembang ke Gamef

Terdapat pelbagai bentuk dalam html5. Peraturan membenarkan penggunaan berbilang teg borang dalam halaman HTML yang sama, bagaimanapun, untuk mengelakkan bahagian belakang daripada tidak mengenalinya semasa menyerahkan, anda perlu menambah ID atau kelas yang berbeza pada borang "url" id=" id value 1">Elemen borang</from><from action="url" id="id value 2">Elemen borang</from>.....".

tidak boleh. Fungsi pernyataan CREATE adalah untuk mencipta struktur jadual, tetapi ia tidak boleh menambahkan rekod baharu Anda boleh menggunakan pernyataan INSERT untuk menambah rekod baharu. Pernyataan CREATE boleh digunakan untuk mencipta jadual baharu dalam pangkalan data dan menentukan atribut dan kekangan lajur data bagaimanapun, jadual yang baru dibuat ialah jadual kosong dan memerlukan penggunaan pernyataan INSERT untuk menambah rekod baharu; Pernyataan INSERT digunakan untuk memasukkan satu atau lebih baris data tuple ke dalam jadual sedia ada dalam pangkalan data.

Teg yang mentakrifkan borang dalam HTML5 ialah "<form>". Teg borang digunakan untuk membuat borang HTML (medan borang) untuk input pengguna untuk mengumpul dan memindahkan maklumat pengguna Semua kandungan dalam borang akan diserahkan kepada pelayan sintaks "<form action="Submit Address" method=". Hantar Kaedah " name="form name">kawalan borang</form>". Borang boleh mengandungi satu atau lebih elemen borang, seperti input, pilih dan textarea.

Artikel ini memberi anda ringkasan terperinci tentang mata pengetahuan yang berkaitan dengan elemen bentuk dalam HTML. Saya harap ia akan membantu anda!

Penyelesaian untuk mencipta ralat aplikasi reaksi: 1. Tukar sumber imej Taobao melalui "npm config set registry https://registry.npm.taobao.org" 2. Dengan melaksanakan "E:\workspace\demo\p4>npx create- perintah react-app todolist" untuk memasangnya semula.

Penyelesaian kepada borang tidak boleh diserahkan kepada PHP: 1. Buka fail kod yang sepadan 2. Ubah suai pernyataan "onload="javascript:document.form1.submit(); 3. Tukar nama serah.

php记录搜索引擎蜘蛛爬行记录代码。php教程记录搜索引擎蜘蛛爬行记录代码 center form action=setup.php method=post table align=center tr td服务器:/tdtdinput value=localhost name=server //td /tr tr td用
