9. 表单 - 从零开始学Laravel
上一节课我们学习了从数据库拿数据,下面我们来学习下通过创建一条记录到数据库,常用的操作就是表单的提交了.
我们先看下: http://localhost:8000/posts/1
帖子页好的,下面我们再这个页面添加一个评论框,为了让页面稍微好看点,我们把bootstrap引入吧~
我们打开layout.blade.php
, 修改里面的代码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>从零开始学Laravel - 周继平</title>
<link rel="stylesheet" href="http://cdn.bootcss.com/bootstrap/3.3.0/css/bootstrap.min.css">
{{-- <link rel="stylesheet" href="{{ elixir('css/app.css') }}"> 这行注释的大家删除掉--}}
@yield('header')
</head>
<body>
@yield('content')
@yield('footer')
</body>
</html>
上面注释的这行大家自己删除掉,正式项目的代码不要有没有用的注释的代码,不干净。
打开resources/pages/show.blade.php
, 修改下其中的代码,让页面变的漂亮点:
@extends('layout')
@section('content')
<div class="row">
<div class="col-md-6 col-md-offset-3">
<h1>{{ $post->title }}</h1>
<ul class="list-group">
@foreach ($post->comments as $comment)
<li class="list-group-item">{{ $comment->content }}</li>
@endforeach
</ul>
</div>
</div>
@stop
好,在看下我们的页面:http://localhost:8000/posts/1
新创建的评论我们再来试试别的方式来写这个store
方法:
public function store(Request $request, Post $post)
{
$comment = New Comment(['content' => $request->content]);
$post->comments()->save($comment);
// 跳转到前一个路由
return back();
}
如果使用New Comment(['content' => $request->content]);
, 一定要保证App\Comment
类中的$fillable
属性中已经设置了允许的字段.
当然,在简单点,可以这样:(如果要传入的参数很多,那这样的写法就不是很合适了。)
public function store(Request $request, Post $post)
{
$post->comments()->save(
new Comment(['content' => $request->content])
);
return back();
}
再简单点:
public function store(Request $request, Post $post)
{
$post->comments()->create(
['content' => $request->content]
);
return back();
}
再再简单点:
public function store(Request $request, Post $post)
{
$post->comments()->create($request->all());
return back();
}
使用$request->all()
的风险很大,因为它会将对应模型设置的$fillable允许的所有字段的值都插入到数据库,如果你一定要这么做,那么一定要想好模型层的$fillable
数组内你允许哪些值可以批量插入。
上面的这些方法都可以用,大家看自己的喜欢,不过像上面这样的$post->comments()->create()
链式调用的方法对于代码的可读性来说不好,尤其是控制器中的代码,都是用来处理业务逻辑的,所以最好是可以读通的英文句子,如,给贴子加评论:Add comment to the post
,那么代码我们这么写:
$post->addComment($comment);
先去App/Post.php
编写addComment($comment)
函数,如下:
public function addComment(Comment $comment)
{
return $this->comments()->save($comment);
}
控制器的代码:
public function store(Request $request, Post $post)
{
$post->addComment(
new Comment($request->all())
);
return back();
}
嗯,这样易读性好多了,关于写控制器我的建议是:
- 控制器的类命名通常都是复数的
- 每个控制器内方法不能过多,方法对应restful路由的方法
- 控制器每个方法中的代码通常都是调用方法(重模型,轻控制器,模型如果太乱,模型在分层,或者使用trait),只考虑业务逻辑,不要将实现方法的流程写在这里,如果你的控制器让不懂代码的人能看懂业务逻辑,那说明写的还不错了。