今天在这简单总结一下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(' ',$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模版展示,遇到的无限分类小问题,在此解决,深刻理解,并分享给大家,仅供参考学习。