Laravel学习笔记—简单的文章增删改查实例

    这是第一次真正鼓捣laravel而学做的第一个简单的实例,虽然这个实例很简单,但是过程中也遇到不少的问题,可谓是历经重重的修改,不断调试才把整个实例的功能实现,因为本人为编程小白,所以在编程的过程中总会遇到很多逻辑上的问题,解决起来有时候真的是抓破头皮都想不出个所以然,不知同样学习过程中的你有木有这种问题存在呢?

好了,接下来是我学习的过程记录。


1. 因为我们这里是利用Laravel里面的ORM模型来操纵数据库的数据的,所以我们第一要先创建数据库和表,这里我以数据库 -> web ,表 -> posts为例。

(1)利用navicai链接到数据库里面,创建数据库web和表posts

wKioL1Y7IbDQJvJmAAH_9hi29Zs764.jpg

(2)往表里填充数据字段,这里是随便填写的,以便测试。

(3)数据库创建完毕之后,接下来的一步就是创建ORM模型文件:

wKiom1Y7IYuz1yIXAAKeaG8w740063.jpg 

 

其中use Illuminate\Database\Eloquent\Model;

是使用了上面路径下的Mode类,以便Post类继承Model类的属性。

 

 

 

public $table 'posts';

定义了数据库的表为posts

 

public $primarykey 'id';

定义了表的主键为id

public $timestamps = false;

设置时间戳为false,这里指的是不让系统自动使用createtime_at 和 updatetime_at的功能

 

protected $dateFormat 'U' ;

设置时间格式为UNIX的时间格式

 

protected $fillable ['title''content','id'];

这里地方尤为需要注意:因为这里fillable是设置白名单的内容,倘若不设置该变量的内容的话,那么后面的编辑和修改数据将会失败,这是写这个程序的过程遇到的一个比较值得注意的地方。

 

2.创建ORM模型之后,我们就可以根据我们的需求来构建我们这个文章的访问路由,实现文章的成功访问,以便映射到对应的视图。

(1)创建indexshowsaveeditdelete对应的路由表项,routes文件的内容如下所示:

wKioL1Y7IeiSLbwpAAGxdF8xba4194.jpg 

 

其中PostController@index等的控制器动作是控制器PostController里面所定义的方法,实现文章的各项功能的实现调用。

3.定义PostController控制器的方法

(1)其中PostControllerPost模型一样,都要继承相应的父类,就是对应路径下的Controller控制器。

class PostController extends Controller

(2)定义index显示列表的方法

wKiom1Y7IjyCXl1XAAOmmnNCDo4889.jpg 

 

 

(3)定义$posts 模型实例,因为每一个模型实例都是查询器,所以调用orderby()查询,根据id字段,以升序的方式显示posts表的所以内容。

$posts Post::orderBy('id''asc')->get();

 

 

 

(4)返回指定的视图模板:post目录下的index.blade.php,将$posts的查询内容传递给posts数组

return view('post.index', ['posts' => $posts]);

 

(5)定义show显示每一篇文章的内容方法

 wKioL1Y7IhbB-05tAAFMZZ7jl9I339.jpg 

 

(6)获取传入的id值,然后再用get()函数将内容显示出来

 

$post Post::where('id''='$id)->get();

 

 

(7)返回show视图模板

 

return view('post.show', ['posts' => $post]);

 

(8)定义edit编辑文章的方法

wKiom1Y7Ieqgm2C9AAGRch3kigM749.jpg 

 

9isset()函数判断id参数是否被设置,如果有则获取其id,否则创建$post模型实例

if (isset($id)) {

        $post Post::find($id);

else {
    $post = new Post();
}

 

(10)返回edit视图模板

return view('post.edit')->with('posts', $post);

 

(11)创建save方法

wKioL1Y7IkTDaJEQAAGE1Gr8-Uo863.jpg 

 

12)设置$id =null是对应id可以为可选

public function save(Request $request$id = NULL)

 

 

13)如果id没有被设置,则对应创建对应的id字段值,然后让其他输入内容传入创建新的数据,否则更新对应的字段内容


        if (isset($id)) {
//
            Post::updateOrCreate(['id' => $id], $request->input());

        } else {
            Post::create($request->input());
        }

 

(14)定义destroy删除数据的方法

wKiom1Y7IhnwWqc6AADgOnMLaRU308.jpg 

 

这个地方比较简单,只要传入对应的id字段的内容,便可对应删除,然后重定向到显示列表的posts/index显示列表的路由上。

 

3.以上控制器的内容定义好之后,接下来便是简单对应视图模板的制作了。

(1)index显示模板

wKioL1Y7ImqQzO0IAANl9Xn55Yc493.jpg 

 

(2)show显示模板

wKioL1Y7IpHAWFcRAALtjpLypv8497.jpg 

 

(3)edit编辑和新增模板

wKiom1Y7ImvgsESSAALme7YUz8g246.jpg 

 

 

5.显示测试结果

wKioL1Y7Iryhmrh4AAGmVKTzChI505.jpg 

 

 

(1)show测试:

 wKioL1Y7IuuhZMAVAAER0yO57zM017.jpg

(2)Edit测试

 wKiom1Y7IsCBX3iEAAE1jqy9QOU848.jpg

wKioL1Y7I2OiiAqxAAFcawZl6m4154.jpg 

(3)Add测试

wKioL1Y7IymxZb97AAE7uJaq2o0572.jpg

wKiom1Y7IungYZiYAAF1fQYc01A320.jpg

 

(4)Delete测试

 wKiom1Y7IzzjfWNrAAFeykSLktc098.jpg 

 

问题解决:

1.出现数据无法添加删除,报错日志显示如下:

wKioL1Y7I6SjXld3AASRjz3os_o484.jpg

解决办法:因为没有开启在Post模板中没有定义$fillable白名单内容,所以所以的字段无法更改数据,包括添加数据。

wKiom1Y7I6bxtpaBAAKeaG8w740824.jpg

 

简单的文章增删改查实例到此完成,接下来还会继续完善。