Laravel 5 基础(九)- 表单
首先让我们修改路由,能够增加一个文章的发布。
Route::get('articles/create', 'ArticlesController@create');
然后修改控制器
public function create() {
return view('articles.create');
}
我们返回一个视图,新建这个视图。我们当然可以直接使用HTML建立表单,但我们有功能更好的办法。我们使用一个开源库,Jeffrey Way 开发的illuminate\html。安装依赖库:
composer require illuminate/html
laravel的库需要注册到laravel中才能使用。在 config/app.php
中,我们可以看到 laravel 提供的 provider
字段,这里描述了laravel的库功能。在Laravel Framewirk Service Providers...
最后添加我们新增的 HtmlProvider
'Illuminate\Html\HtmlServiceProvider',
我们不希望使用 Illuminate\Html\FromFacade
这么长的名字来引入,我们需要简短的名字。在当前的 app.php
中找到 aliases 段,在最后添加别名。
'Form' => 'Illuminate\Html\FormFacade',
'Html' => 'Illuminate\Html\HtmlFacade',
OK,现在我们来创建视图,views/articles/create.blade.php
@extends('layout')
@section('content')
<h1>Write a New Article</h1>
<hr/>
{{--使用我们添加的 illuminate\html 开源库--}}
{!! Form::open() !!}
{!! Form::close() !!}
@stop
访问 /articles/create
看到了错误,Why? 让我们测试一下,到底是哪里出了问题。在控制器中做出下面的修改:
public function show($id) {
dd('show');
$article = Article::findOrFail($id);
return view('articles.show', compact('article'));
}
没错,你没看错,就是在 show
方法中添加 dd()
方法,这个方法简单的输出一个信息然后死掉。我们再来访问 /articles/create
,你看到了什么,你看到输出了 show
。
为什么我们访问 create
结果路由给了我们 show
? 我们来查看一下路由,到底发生了什么。
Route::get('articles', 'ArticlesController@index');
Route::get('articles/{id}', 'ArticlesController@show');
Route::get('articles/create', 'ArticlesController@create');
上面是我们的路由,注意到 articles/{id}
意味着这是一个通配符,所有在 articles/
后面的东西都会匹配,你知道了么?我们的 /articles/create
也被他匹配了。OMG!
解决方案就是调整顺序:
Route::get('articles', 'ArticlesController@index');
Route::get('articles/create', 'ArticlesController@create');
Route::get('articles/{id}', 'ArticlesController@show');
也就是从特殊到普通,以后的路由设置中要时刻注意这个问题。现在我们在访问 articles/create
一切OK了。
在浏览器中查看一下源代码,你会发现不仅生成了 method
和 action
同时生成了一个隐藏的 _token
字段作为服务器对窗体的验证,避免黑客的伪造攻击。
让我们修改我们的视图,添加字段:
@extends('layout')
@section('content')
<h1>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
当表单提交的时候,实际上是使用 post
方法提交到 articles/create
上的,但根据RESTful的习惯,我们希望能够 post
到 /articles
上,我们来修改视图的表单方法,设定提交的路径。
{!! Form::open(['url' => 'articles']) !!}
然后我们在路由中处理表单提交事件。
Route::post('/articles', 'ArticlesController@store');
我们来处理控制器
//注意:将下面的 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;
}
我们可以直接看到输入表单的json结果。如果只需要 title
字段的值,则可以使用 Request::get('titel')
。
如何添加到数据库中呢?借助模型,我们可以直接采用下面的方法,
Article::create($input);
就这么简单,就是这么任性
如果没有忘记 Mass Assignment,在我们的模型中我们定义了 $fillable
数组,来定义那些字段可以直接在 create
的时候直接填充。
修改控制器,添加到模型中,并存储到数据库。
public function store() {
$input = Request::all();
Article::create($input);
return redirect('articles');
}
添加一条记录试试,非常棒。但别忘了。我们还有一个字段叫做 published_at
,让我们来处理它。
public function store() {
$input = Request::all();
$input['published_at'] = Carbon::now();
Article::create($input);
return redirect('articles');
}
添加新纪录在测试一下。
还有一个问题,新添加的应该显示在最前面,我们来修改以下控制器。
public function index() {
//倒序获取文章
//可以这样
//$articles = Article::orderBy('published_at', 'desc')->get();
//简单方式,当然还有 oldest()
$articles = Article::latest('published_at')->get();
return view('articles.index', compact('articles'));
}
Laravel 5 基础(九)- 表单的更多相关文章
- Bootstrap<基础六> 表单
Bootstrap 通过一些简单的 HTML 标签和扩展的类即可创建出不同样式的表单. 表单布局 Bootstrap 提供了下列类型的表单布局: 垂直表单(默认) 内联表单 水平表单 垂直或基本表单 ...
- Laravel教程 七:表单验证 Validation
Laravel教程 七:表单验证 Validation 此文章为原创文章,未经同意,禁止转载. Laravel Form 终于要更新这个Laravel系列教程的第七篇了,期间去写了一点其他的东西. 就 ...
- Laravel教程 六:表单 Forms
Laravel教程 六:表单 Forms 此文章为原创文章,未经同意,禁止转载. Form laravel 5.2 之后请使用 laravelcollective/html 替换 illuminate ...
- 【ASP.NET 基础】表单和控件
1.HTML表单的提交方式 对于一个普通HTML表单来说,它有两个重要的属性:action 和 method.action属性指明当前表单提交之后由哪个程序来处理,这个处理程序可以是任何动态网页或者 ...
- Laravel框架中Form表单Get请求搜索(在此感谢[https://simon8.com])
首先看一下HTML部分的Form表单 <form role="search" method="get" id="searchform" ...
- Laravel用post提交表单常见的两个错误
最近在自学Laravel,测试用post方法提交表单时碰到两个错误: 1.获取传入的值时,报错如下图所示: 在stackFlow找答案时各种解释都有,但认真读一下报错信息,意思大概是:获取Http传入 ...
- 最适合入门的Laravel中级教程(三)表单验证
做开发有个原则是永远不能信任用户输入的数据: 即便前端已经做了验证: 在后端 php 也必须要再次验证: laravel 为表单验证提供了强大且简单的方案: 创建示例路由: routes/web.ph ...
- laravel中,提交表单后给出提示例如添加成功,添加失败等等
laravel中的表单插入,我想在表单插入成功后,可以像thinkphp一样可以有一个提示内容,上网Google,他们还是给出的方法就是 return redirect('/')->with(' ...
- 玩转Django2.0---Django笔记建站基础七(表单与模型)
第七章 表单与模型 表单是搜集用户数据信息的各种表单元素的集合,作用是实现网页上的数据交互,用户在网站输入信息,然后提交到网站服务器端进行处理(如数据录入和用户登录.注册等). 用户表单是web开发的 ...
- 走进AngularJs(九)表单及表单验证
年底了越来越懒散,AngularJs的学习落了一段时间,博客最近也没更新.惭愧~前段时间有试了一下用yeoman构建Angular项目,感觉学的差不多了想做个项目练练手,谁知遇到了一系列问题.yeom ...
随机推荐
- sqoop安装
环境:Hadoop 2.3.0 sqoop 1.4.5 1.下载并解压sqoop-1.4.6.bin__hadoop-2.0.4-alpha.tar.gz (解压完,名字会很长,可以根据需要自己修改下 ...
- spring获取bean的时候严格区分大小写
如题:spring获取bean的时候严格区分大小写 配置文件helloservice.xml中配置: <dubbo:reference id="IInsurance" int ...
- css3实现小米商城鼠标移动图片上浮阴影效果
今天在编程爱好者编码库看见一个好玩的程序,代码如下. <!DOCTYPE html> <html> <head> <meta charset=&quo ...
- 读书笔记--编程珠玑II
学化学的应该都知道chemdraw,这是一款专门绘制化学结构的软件,什么苯环.双键各种word难以搞定的分子式,你可以轻松的用chemdraw完成,可以称得上化学工作者居家旅行必备的良药.其实早在19 ...
- Linux 串口使用
1. 安装串口调试工具minicom sudo apt-get install minicom 2. 查看串口端口 cfm@cfm880:~$ dmesg | grep tty[ 0.000000] ...
- 25_android下文件访问的权限
写文件:FileOutputStream fos = 上下文.openFileOutput("private.txt",Context.MODE_PRIVATR);参数1 文件名, ...
- iOS地址编码解析
- (void)viewDidLoad { [super viewDidLoad]; // 创建地址解析器 self.geocoder = [[CLGeocoder alloc] init]; } - ...
- [SSH 2] 以网站主页面浅谈Struts2配置
导读:前面总体的介绍了一下SSH框架,那么作为Struts这一支,具体是怎么配置的呢?本篇博客则主要是以自己做过的实例中的登录一条线,简单介绍一下struts2的配置,如有不妥之处,还请大家多提点提点 ...
- 2016-03-10:libx265源码解析
单步跟踪执行流程 将cli设定为启动项目,在属性->调试->命令行参数中设置如下参数: --input E:\video\pedestrian_area.yuv --fps 24 --in ...
- 用C#访问SSRS自动导出SSRS报表
一. 新建一个winform应用程序WindowsFormsApplication1 二. 添加web引用 . 报表服务:http://dbpdhk ...