PHP-无限分类-下拉列表实现

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/garvisjack/article/details/57389443

今天在这简单总结一下php里无限分类的用法,当然在实际项目或者业务中,是一定结合着数据库来完成的,这里我是在做MVC架构练习中,封装了无限分类的Model类来完成的,纠结了一段时间,所以特此写blog总结,无限分类的入门理解

什么是无限级分类?
  无限级分类是一种分类技巧,例如部门组织,文章分类,学科分类等常用到无限级分类,将其简单理解成分类就好了。其实我们仔细想一下,生活中的分类简直太多了,中国34个省,每个省有市,有区,这就是无限分类。
  
无限级分类原理简介
  无限分类好像很难操作一样,实际上原理是非常简单的 ,就是递归函数的原理,无限分类不仅仅需要代码的巧妙性,也要依托数据库设计的合理性。要满足无限级分类,数据库需要有两个必须的字段,id,pid。id用来标识自身,而pid则是用来表明父级id。也就是说,每个分类记录不仅描述了自身,还描述了与其关心最为紧密的另一个id。当然这是最简单的数据库制表方法可以实现的。下面我们举例

数据库简单的表格搭建,这里相信大家都会。。
这里写图片描述

这是最简单的数据表模式,主要就是pid,父亲的ID,以小米的产品举例,可以看到大致只有2级的分类。
接下来熟悉mysql和php的朋友们肯定知道了,我们可以连接数据库,通过方法得到一个资源数组,也就是一个二维数组$array.

我这里是用自己封装的一个db类,提取得到数组
入门的大家,也可以先面向过程,提取

**类的提取**
  /**
     * 正常所有商品分类展示,得到一个数组集合
     * @return array
     */
    public function show(){
        $db = Db::getInstance();
        $res = $db->query("select * from tb_category");
        if(is_resource($res)) {
            $arr = $db->fetchAll($res);
        }
        return $arr;
    }

**连接提取**

<?php
    require_once('config.php');
    //连接数据库
    $con = @mysql_connect(HOST,USERNAME,PASSWORD) or die('连接数据库失败!');
    //选择数据库
    @mysql_select_db("db_info");
    //定义字符集
    mysql_query("set names utf8");

?>

那么我们此次的目的是得到什么呢?没错,就是比较常用的一个下拉列表,在后台管理的时候,常会用到,我这边也是用封装的类提取的,我会简单讲一下.

我们的目标:
这里写图片描述

在上面我们用得到的二维数组,进行一个简单的数组变换操作即可

  public function getList(&$result=array(),$pid=0,$spac=0){
        $spac=$spac+4;
        foreach($this->show() as $value){
            if($value['pid']==$pid){
                $value['type'] = str_repeat('&nbsp;',$spac)."|--".$value['type'];
                $result[] = $value;
                $this->getList($result,$value['id'],$spac);
            }
        }
        return $result;
    }

我这用到的是一个类方法,直接当作函数来理解即可
传入三个可选参数,一个引用的数组参数,一个默认的pid,一个空格符计数

原理:
遍历这个这个二维数组,当它的父级pid和顶级0相同时候,提取数组名字,重新编辑,加上前缀,放回去,然后再自己调用自己,完成一次递归,到下一次,如果有下一级别的pid,则继续调用,这样就能简单实现效果,得到一个树形结构的新的二维数组$result!

最后我再将这个二维数组进行加工,放在下拉列表的标签里,遍历输出字符串到前台,或者html结构中,就可以完成上面我们要的效果了!

public function displayList($id=0){
        $str = "";
        $result = $this->getList();
        //这里去更新部分的展示数据,用其中的pid去对比
        $arr = $this->update($id);
        if($id!=0) {
            //当不需要编辑时候,在查询页面正常显示下拉列表
            foreach ($result as $value) {
                //这里特别注意,在model部分判断一把,选中的编辑pid和展示的下拉id相同时候选中
                if($value['id']==$arr['pid']) {
                    $str .= "<option value='{$value['id']}' selected>{$value['type']}</option>";
                }
                else{
                    $str .= "<option value='{$value['id']}'>{$value['type']}</option>";
                }
            }
            return $str;
        }
        else{
            foreach ($result as $value) {
                $str .= "<option value='{$value['id']}'>{$value['type']}</option>";
            }
            return $str;
        }

        }

这是最简答级别的无限分类技术,当然在数据庞大的时候,会有其他的方法可以帮助我们实现不同的效果,我这里是在做mvc架构搭建时候,用smarty模版展示,遇到的无限分类小问题,在此解决,深刻理解,并分享给大家,仅供参考学习。

展开阅读全文

没有更多推荐了,返回首页