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教程有兴趣的朋友有所帮助。

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

BinaryX的代币更名:从BNX到FOUR,再到FORM,战略调整背后的深层含义BinaryX近期将代币符号从$FOUR更改为$FORM,引发业界广泛关注。这并非BinaryX首次更名,其代币符号曾经历BNX到FOUR的转变。本文将深入探讨这一系列更名背后的战略意图。一、代币更名历程与战略考量BinaryX最初于2021年推出基于BNB链的$BNX代币,用于支持其Play-to-Earn(P2E)游戏生态。2024年初,为优化经济模型,BinaryX对$BNX进行了分割,并逐渐拓展至GameF

html5中可以有多个form。在同一个HTML的页面中规则上允许可以用到多个form标签,但是为了防止提交时后台无法识别,需要给表单加上不同的ID或者class,语法“表单元素表单元素.....”。

不能。CREATE语句的功能是创建一个表结构,但不能追加新的记录,追加新的记录可以使用INSERT语句。CREATE语句可用于在数据库中创建新表,并规定数据列的属性和约束;但新建的表是一个空表,需要使用INSERT语句追加新的记录。INSERT语句用于向数据库已有的表中插入一行或者多行元组数据。

html5定义表单的标签是“”。form标签用于创建供用户输入的HTML表单(表单域),以实现用户信息的收集和传递,form中的所有内容都会被提交给服务器;语法“表单控件”。form表单中可包含一个或多个表单元素,比如input、select、textarea。

creat react app报错的解决办法:1、通过“npm config set registry https://registry.npm.taobao.org”切换淘宝镜像源;2、通过执行“E:\workspace\demo\p4>npx create-react-app todolist”命令重新安装即可。

form表单无法提交到php的解决办法:1、打开相应的代码文件;2、修改“onload="javascript:document.form1.submit();”语句;3、将submit的name进行更改一下即可。

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