PHP開發(fā)之分類技術(shù)利用foreach循環(huán)實(shí)現(xiàn)分類功能
什么是分類呢?就像windows下新建一個(gè)文件夾,在新建的文件夾下又可以新建
一個(gè)文件夾,這樣無限循環(huán)下去,分類也是這樣,父類可以分出它子類,子類又
可以分出它的子類。。。。。。
那PHP又是如何實(shí)現(xiàn)它的分類的呢?如何把它的各個(gè)分類一一列出來呢?
本章節(jié)我們將介紹使用foreach循環(huán)來實(shí)現(xiàn)分類功能。
首先構(gòu)建一個(gè)分類數(shù)組:
<?php $categories = array( array('id'=>1,'name'=>'電腦','pid'=>0), array('id'=>2,'name'=>'手機(jī)','pid'=>0), array('id'=>3,'name'=>'筆記本','pid'=>1), array('id'=>4,'name'=>'臺(tái)式機(jī)','pid'=>1), array('id'=>5,'name'=>'智能機(jī)','pid'=>2), array('id'=>6,'name'=>'功能機(jī)','pid'=>2), array('id'=>7,'name'=>'超級(jí)本','pid'=>3), array('id'=>8,'name'=>'游戲本','pid'=>3), ); ?>
這里有3個(gè)字段, 排序id, ? 分類名稱name,和分類pid
目標(biāo)是將它轉(zhuǎn)化為下面這種結(jié)構(gòu):
<?php array( //1對(duì)應(yīng)$categories中的id ,方便直接讀取 1 => array( 'id'=>1, 'name'=>'電腦', 'pid'=>0, 'children' =>array( array( 'id'=>3, 'name'=>'筆記本', 'pid'=>1, 'children'=>array( 'id'=>7, 'name'=> '超極本', 'pid'=>'3' ), array( 'id'=>8, 'name'=> '游戲本', 'pid'=>'3' ) , ), array( 'id'=>4, 'name'=>'臺(tái)式機(jī)', 'pid'=>1, ), ), ), 2 => array( 'id'=>2, 'name'=>'手機(jī)', 'pid'=>0, 'children' =>array( array( 'id'=>5, 'name'=>'智能機(jī)', 'pid'=>2, ), array( 'id'=>6, 'name'=>'功能機(jī)', 'pid'=>2, ), ), ), ); ?>
實(shí)現(xiàn)過程:
創(chuàng)建一個(gè)空數(shù)組
<?php $tree = array(); ?>
第一步,將所有的分類id作為數(shù)組key,并創(chuàng)建children單元
<?php foreach($categories as $category){ $tree[$category['id']] = $category; $tree[$category['id']]['children'] = array(); } ?>
第二步,利用引用,將每個(gè)分類添加到父類children數(shù)組中,這樣一次遍歷即可形成樹形結(jié)構(gòu)。
<?php foreach ($tree as $key=>$value) { if ($value['pid'] != 0) { $tree[$value['pid']]['children'][] = $tree[$key]; } } ?>
最后使用print_r();打印出來
<?php print_r($tree); ?>
優(yōu)點(diǎn):關(guān)系清楚,修改上下級(jí)關(guān)系簡單。
缺點(diǎn):使用PHP處理,如果分類數(shù)量龐大,效率也會(huì)降低。