网创优客建站品牌官网
为成都网站建设公司企业提供高品质网站建设
热线:028-86922220
成都专业网站建设公司

定制建站费用3500元

符合中小企业对网站设计、功能常规化式的企业展示型网站建设

成都品牌网站建设

品牌网站建设费用6000元

本套餐主要针对企业品牌型网站、中高端设计、前端互动体验...

成都商城网站建设

商城网站建设费用8000元

商城网站建设因基本功能的需求不同费用上面也有很大的差别...

成都微信网站建设

手机微信网站建站3000元

手机微信网站开发、微信官网、微信商城网站...

建站知识

当前位置:首页 > 建站知识

如何编写Laravel5框架的表单-创新互联

这篇文章主要介绍“如何编写Laravel 5框架的表单”,在日常操作中,相信很多人在如何编写Laravel 5框架的表单问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何编写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')
  

Write a New Article

  
  {{--使用我们添加的 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')
  

Write a New Article

  
  {{--使用我们添加的 illuminate\html 开源库--}}   {!! Form::open() !!}            {!! Form::label('title', 'Title:') !!}       {!! Form::text('title', null, ['class' => 'form-control']) !!}     
           {!! Form::label('body', 'Body:') !!}       {!! Form::textarea('body', null, ['class' => 'form-control']) !!}     
           {!! Form::submit('Add Article', ['class' => 'btn btn-primary form-control']) !!}     
  {!! 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框架的表单”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!


网站栏目:如何编写Laravel5框架的表单-创新互联
分享链接:http://bjjierui.cn/article/jocoh.html

其他资讯