从Thinkphp5看RCUD

作者: 沙蒿同学 | 来源:发表于2018-01-27 20:33 被阅读15次

    基础知识

    看这篇文章前,你需要理解thinkphp5的几个概念

    入口文件:ThinkPHP采用单一入口模式进行项目部署和访问,无论完成什么功能,一个应用都有一个统一(但不一定是唯一)的入口。

    ps:就好像你去医院,有一个统一的大门出入,不管你去哪个楼层都要先经过这个大门,
    这样做的理由很简单,统一管理,方便而且安全。
    

    模块名:也就是Module M层,通常有index、admin和common这三个模块,你可以理解为前台、后台和公共;一般这个文件夹有各种控制器(controller)

    ps:common模块是一个特殊的模块,默认是禁止直接访问的,
    一般用于放置一些公共的类库用于其他模块的继承
    

    控制器:controller C层;可继承官方封装的\think\Controller类或者其他的控制器类

    ps:可以理解为一个类,内含各种方法,也就是下面要说的触发器(A层)
    

    触发器:action A层;又叫函数、function、method;原因大概是由于这个function如果想被执行的话,需要用户输入特定的URL。我们说当用户输入特定的URL后,这个方法被触发了,所以叫做触发器

    image.png
    上图,应用文件(application)、模块、控制器和触发器一一对应,
    椭圆框为触发器,是不是就是类的方法。url上也是一一对应以上的文件。
    

    RCUD 之Read Retrieve

    从数据库表里读取数据;有一种叫M数据模型层来读取数据,thinkphp5内置的一个类think\Model,这个类中封装好了所有的数据库操作方法,我们只需要在application文件下新建一个common文件,里边有文件model,model里有.php后缀的类(文件名与类名相同),有兴趣的可以去看下开发文档,这里不细讲,我们采用一种简单的方法来读取数据。

    取数据:$items = Db::name('数据表名')->select()
    想V层传数据:$this->assign('items', $items);
    将数据返回给用户:return $this->fetch();
    前端显示:使用内置标签volist循环输出一个数组

    ps:DB调用name方法无需数据表前缀,返回的变量类型是个array;
    V层,也就是view视图层
    更多thinkphp5内置标签(eq、switch等)可以查看thinkphp5官方手册[http://www.kancloud.cn/manual/thinkphp5/118003](http://www.kancloud.cn/manual/thinkphp5/118003)
    
    

    RCUD 之Create

    插入数据;把表单提交的数据插入到数据库表中;

    form表单add数据:{:url('insert')}
    insert触发器接收数据: $postData = Request::instance()->post();
    插入数据到数据库表:$postData->save()(这里$postDara是一个实例化 对象)
    返回结果:return $this->success('插入成功',url('index'));

    ps:Request是一个thinkphp5里的类,为了防止sql注入,出于安全性考虑。
    

    RCUD 之Delete

    删除数据;采用关键字删除可以有效准确的删除我们不要的数据;

    a标签提交关键字:<a href="{:url('delete?id=' . $item->getData('id'))}">删除</a>
    delete触发器接收id:$id = Request::instance()->param();
    获取要删除的对象:$item= Item::get($id);
    删除对象:$Item->delete()

    ps:$item是一个实例化的对象
    

    RCUD 之Update

    更新数据;更新数据是前面select和insert的步骤结合,先读取数据,在展示数据,然后修改数据,接着传递数据和接收数据,最后更新数据(有点晕,但其实很简单啦)

    相关文章

      网友评论

        本文标题:从Thinkphp5看RCUD

        本文链接:https://www.haomeiwen.com/subject/uavnaxtx.html