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

WBOY
Libérer: 2016-06-20 12:45:10
original
1186 Les gens l'ont consulté


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

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

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


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

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

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

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

 

 

其中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)创建index,show,save,edit,delete对应的路由表项,routes文件的内容如下所示:

 

 

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

3.定义PostController控制器的方法

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

class PostController extends Controller

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

 

 

 

(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显示每一篇文章的内容方法

  

 

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

 

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

 

 

(7)返回show视图模板

 

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

 

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

 

 

(9)isset()函数判断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方法

 

 

(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删除数据的方法

 

 

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

 

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

(1)index显示模板

 

 

(2)show显示模板

 

 

(3)edit编辑和新增模板

 

 

 

5.显示测试结果

 

 

 

(1)show测试:

 

(2)Edit测试

 

 

(3)Add测试

 

(4)Delete测试

  

 

问题解决:

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

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

 

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

 

 


source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal