PHP-无限级分类
给定省市地区数组如下:
$area = array(
array('id'=>1,'name'=>'安徽','parent'=>'0'),
array('id'=>2,'name'=>'海淀','parent'=>'7'),
array('id'=>3,'name'=>'濉溪县','parent'=>'5'),
array('id'=>4,'name'=>'昌平','parent'=>'7'),
array('id'=>5,'name'=>'淮北','parent'=>'1'),
array('id'=>6,'name'=>'朝阳','parent'=>'7'),
array('id'=>7,'name'=>'北京','parent'=>'0'),
array('id'=>8,'name'=>'上地','parent'=>'2')
);
无限级分类的应用有如下几种:
1、找指定栏目的子栏目
2、找指定栏目的子孙栏目--子孙树
3、找指定栏目的父栏目/父父栏目....------家谱树
#找指定栏目的子栏目#
function sontree($arr,$id=0){//默认从顶级栏目开始找 $son = array(); foreach($arr as $v){ if($v['parent'] == $id){ $son[] = $v; } }
return $sons;
} echo '<pre>'; print_r(sontree($area,0)); echo'</pre>';
#找指定栏目的子孙栏目--子孙树#
function substree($arr,$id=0,$jibie=0){ $tree = array(); foreach($arr as $v){ if($v['parent'] == $id){ $tree[] = $v; $v['jibie'] = $jibie; $tree = array_merge($tree,subtree($arr,$v['id']),$jibie+1); } return $tree; } } echo '<pre>'; print_r(substree($area,0)); echo'</pre>';
//真实案例:部门职工树
private function _deptspns($lv,$pid){
$db = m('dept');
$s = '';
$r = m('admin')->getone("id='".$this->adminid."'",'type,deptid');
if($r['type']==0)$s = ' and id=\''.$r['deptid'].'\'';
$rows = $db->getall(" `pid`='".$pid."' $s order by `sort`",'*');
$da = array();
if(count($rows)){
foreach($rows as $k=>$mv){
$da[$k] = array(
'id'=>$mv['id'],
'lv'=>$lv,
'name'=>$mv['name'],
'pid'=>$mv['pid'],
'expanded'=>true
);
$da[$k]['children'] = $this->_deptspns($lv+1,$mv['id']);
}
}
return $da;
}
$da = $this->_deptspns(1,0);
//方法二(static)
function substree($arr,$id=0,$jibie=0){ static $tree = array(); foreach($arr as $v){ if($v['parent'] == $id){
$v['jibie'] = $jibie;
$tree[] = $v;
subtree($arr,$v['id']),$jibie+1); } return $tree; } } echo '<pre>'; print_r(substree($area,0)); echo'</pre>';
#家谱树#
//方法一
function parenttree($arr,$id=0){ $par = array(); foreach($arr as $v){ if($v['id'] == $id) { if($v['parent'] > 0){ //如果为0就是顶级 它没有父栏目.... array_merge($par,parenttree($arr,$v['[parent'])); $par[] = $v;//第一次把自己存入
/*把$par[] = $v;/写在后面 array_merge($par,parenttree($arr,$v['[parent']));就是先进后出
结果可以是:北京-》海淀-》上地
写在前面结果相反
递归递归-先递在归
*/ } } } return $par; } echo '<pre>'; print_r(parenttree($area,0)); echo '</pre>';
方法二:
function parenttree($arr,$sid=0,$jibie=1){
static $parent = array();
static $pid = null;
foreach($arr as $val){
if($sid == $val['id']){
$pid = $val['parent'];
//$parent[] = $val;
}
}
foreach($arr as $val1){
if($pid == $val1['id']){
$val1['jibie'] = $jibie;
$parent[] = $val1;
parenttree($arr,$pid,$jibie+1);
}
}
return $parent;
}
echo '<pre>';
print_r(parenttree($area,8,1));
echo '</pre>';
exit;
$parent_arr = parenttree($area,8,1);
foreach($parent_arr as $val){
echo @str_repeat('      ',$val['jibie']),$val['name'],'<br/>';
}
/*
经过测试这个方法我只求出了它的父亲以上的栏目,它自己没有存入,也请大家帮忙修改
这个方法造成的缺陷就是在例如面包屑导航条上有bug
*/
PHP-无限级分类的更多相关文章
- PHP无限级分类的实现(不使用递归)
无限级分类在开发中经常使用,例如:部门结构.文章分类.无限级分类的难点在于“输出”和“查询”,例如 将文章分类输出为<ul>列表形式: 查找分类A下面所有分类包含的文章. 1.实现原理 在 ...
- 一道无限级分类题的 PHP 实现
今天有网友出了道题: 给出如下的父子结构(你可以用你所用语言的类似结构来描述,第一列是父,第二列是子),将其梳理成类似如图的层次父子结构. origin = [('A112', 'A1122'), ( ...
- (实用篇)PHP递归实现无限级分类
在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢?我们在本文中使用递归算法并结合mysql数据表实现无限级分类. 在一些复杂的系统中,要求对信 ...
- php利用递归函数实现无限级分类
相信很多学php的很多小伙伴都会尝试做一个网上商城作为提升自己技术的一种途径.各种对商品分类,商品名之类的操作应该是得心应手,那么就可以尝试下无限级分类列表的制作了. 什么是无限级分类? 无限级分类是 ...
- PHP+MySQL无限级分类(非递归)
要实现无限级分类,递归一般是第一个也是最容易想到的,但是递归一般被认为占用资源的方法,所以很多系统是不考虑使用递归的 本文还是通过数据库的设计,用一句sql语句实现 数据库字段大概如下: 字段 说明 ...
- PHP无限级分类-递归(不推荐)
[http://www.helloweba.com/view-blog-204.html] 在一些复杂的系统中,要求对信息栏目进行无限级的分类,以增强系统的灵活性.那么PHP是如何实现无限级分类的呢? ...
- PHP无限级分类生成树实例代码
分享一例php无限级分类生成树的代码,学习下php无限级分类的实现方法,有需要的朋友参考下. 一段非常精简的PHP无限极分类生成树方法,巧在引用. 例子,php实现无限级分类. 代码示例: ...
- php非递归无限级分类.
项目需要.递归无限级分类效率实在太低.理了半天思路写的. 分类越多效率越高. /** * 单次循环返回无限极分类嵌套 * @param array $data 操作的数组 * @param strin ...
- 转:php+mysql菜单无限级分类(非递归)
php+mysql无限级分类(非递归) 参考:http://www.chhua.com/web-note3244
- SQL 无限级分类语句
原文:SQL 无限级分类语句 原表数据为: 此处用到了with关键字,在程序中也可以用递归实现,但觉得还是没有一条sql方便 with tb (ID,Name,ParentID,Sort) as( s ...
随机推荐
- UITextField的使用小技巧
[tf setValue:[UIColor redColor] forKeyPath:@"_placeholderLabel.textColor"];//修改placeHolder ...
- 文件夹的创建(cmd利用)
在windows本地上创建文件夹是无法用..结束的,我们要创建的话,需要在cmd里面进行创建输入 mkdir abc..\ 那么我们从本地看出abc..文件夹建成了怎么删除呢? 需要手动在里面建个文件 ...
- Netty之粘包分包
粘包现象 客户端在一个for循环内连续发送1000个hello给Netty服务器端, Socket socket = new Socket("127.0.0.1", 10101); ...
- 防止UI穿透操作到游戏场景
#if UNITY_EDITOR || UNITY_STANDALONE_WIN if (EventSystem.current.IsPointerOverGameObject()) { return ...
- Linux安装Nginx以及简单理解
1.Nginx简单介绍 ①.Nginx:一个高性能的HTTP和反向代理服务器,高并发处理很不错. ②.反向代理:在计算机世界里,由于单个服务器的处理客户端(用户)请求能力有一个极限,当用户的接入请求蜂 ...
- 升级安装php7要考虑的几个方面
php7从推出到现在,前两天官方已经发布到7.2版本,把自己升级和安装php7中遇到的问题和解决方法做一个笔记,内容主要包括:1) mysql2) php3) nginx4) memcache扩展5) ...
- IDE转AHCI
1.Win + R.输入regedit.进入注冊表编辑器 2.找到HKEY_LOCAL_MACHINE\System\CurrentControlSet\Services\Msahci.将当中的&qu ...
- 优化Webpack构建性能的几点建议
Webpack 作为目前最流行的前端构建工具之一,在 vue/react 等 Framework 的生态圈中都占据重要地位.在开发现代 Web 应用的过程中,Webpack 和我们的开发过程和发布过程 ...
- 自学WPF之Binding(一)
Binding的重要性就不作介绍了,是作为数据交互的支撑,下面来介绍一下为Binding指定源(Source)的几种方法: 把普通CLR类型的单个对象指定为Source:包括.NET Framewor ...
- 通过gitbub桌面工具同步
1.先创建目录,和选择路径 2.commit -> sync 3. cd ~/.ssh 查看公钥 在github 添加公钥. 4. 克隆文件git clone git@github.con:cu ...