zoukankan      html  css  js  c++  java
  • ThinkPHP删除栏目(单)

      当我们做一些网站项目的时候,都会遇到这样一类问题,删除一个栏目,而这个栏目又不是最底层栏目,也就是说,被删除的栏目拥有子栏目,这时,我们执行删除该栏目的命令,就需要将该栏目及其子栏目一并删除,因为我们不可能让一个类的上级栏目被删除后,子栏目还显示或存在数据库中,这时候,栏目删除的问题就来了。

    先上图:

      这是一个简单的权限管理的页面,图中管理员权限为顶级权限,栏目管理为管理员权限的子权限,栏目添加又为栏目管理的子权限,这样一个三级分类,我们想要达到的效果为:删除管理员权限,其下栏目管理、栏目添加权限全被同时删除;删除栏目管理权限,则栏目添加也同时被删除;删除栏目添加权限则只删除其本身。

    接下来实现方法:

    1.是控制器中简单删除方法:

    1     public function privilege_del(){
    2         $pri = D('privilege');
    3         $id = I('id');
    4         if($pri->delete($id)){
    5             $this->success('删除权限成功!',U('Privilege/privilege_lst'));
    6         }else{
    7             $this->error('删除权限失败!');
    8         }
    9     }

    2.我们思考,我们想要的同时删除的结果,其实是当我们选择上级栏目删除时,代码首先帮我们删除该栏目类别的最底层的子栏目,然后依次向上删除,最终删除我们选择的上级栏目,所以我们需要写一个前置的构造函数进行操作 _before_delete($options) 这是ThinkPHP提供给我们的函数,他的用法是在我们执行删除方法前,执行这个函数,其中$options为我们要删除的信息,具体为一个二维数组,当我们把$options dump出来时,结果为:                                                                                                                                                                                                                                                                                     

      也就是说,如果我们想要取到这条信息的id值,只需要获取$options['where']['id']即可,但是注意,如果数组中的where同样是一个数组的时候,这就意味着我们进行的是批量删除,这也是单个删除和批量删除的区别所在,关于批量删除,之后我会再写一篇来简单介绍,这次我们只写单个删除。

      首先,写一个获取所有数据的方法childid,这里的$priid就是我们传进去的所要删除的那一栏的id

    1 public function childid($priid){
    2         $data = $this->select();
    3         return $this->getchildid($data,$priid);
    4     }

      然后根据所有数据查找我们要删除的栏目的下面的子栏目的id,再次创建一个方法 getchildid获取所有需要删除的id

     1 public function getchildid($data,$parentid){
     2         static $ret=array();
     3         foreach ($data as $k => $v) {
     4             if($v['parentid']==$parentid){
     5                 $ret[]=$v['id'];
     6                 $this->getchildid($data,$v['id']);
     7             }
     8         }
     9         return $ret;
    10     }

    这里又用到了递归,在所有数据中查询完下级栏目后,查询下级栏目的下级栏目,最后将该栏目的所有子栏目的id版存到ret数组中,返回。

    最后在构造函数中调用

    1      public function _before_delete($options){
    2         //单个删除
    3         $chilrenids =$this->childid($options['where']['id']);
    4         $chilrenids = implode(',', $chilrenids);    
    5         if($chilrenids){
    6             $this->execute("delete from ed_privilege where id in($chilrenids)");
    7         }
    8     }

    将获取的id号用逗号隔开,因为此时不能再使用delete方法去删除数据,若使用则将再次调用构造函数成为死循环,所以我们需要在这里执行SQL语句进行数据删除。

    以上就是单个栏目删除的全部内容。

  • 相关阅读:
    C# 16 进制字符串转 int
    C# 16 进制字符串转 int
    dotnet 设计规范 · 抽象定义
    dotnet 设计规范 · 抽象定义
    C# 从零开始写 SharpDx 应用 控制台创建 Sharpdx 窗口
    C# 从零开始写 SharpDx 应用 控制台创建 Sharpdx 窗口
    C# 判断两条直线距离
    C# 判断两条直线距离
    PHP file() 函数
    PHP fgetss() 函数
  • 原文地址:https://www.cnblogs.com/zlnevsto/p/7051875.html
Copyright © 2011-2022 走看看