亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

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):

QQ圖片20161102150838.png

<?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ì)降低。

繼續(xù)學(xué)習(xí)
||
<?php header("content-type:text/html;charset=utf-8"); //利用兩個(gè)foreach來實(shí)現(xiàn)分類功能 /* 1. 構(gòu)建字段 字段名 字段類型 備注 默認(rèn)值 id int 主鍵 auto-increment name varchar 分類名稱 pid int 父類id 0 */ //先來構(gòu)建一個(gè)原始數(shù)組 $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), ); 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, ), ), ), ); //處理過程 $tree = array(); //第一步,將所有的分類id作為數(shù)組key,并創(chuàng)建children單元 foreach($categories as $category){ $tree[$category['id']] = $category; $tree[$category['id']]['children'] = array(); } //第二步,利用引用,將每個(gè)分類添加到父類children數(shù)組中,這樣一次遍歷即可形成樹形結(jié)構(gòu)。 foreach ($tree as $key=>$value) { if ($value['pid'] != 0) { $tree[$value['pid']]['children'][] = $tree[$key]; } } print_r($tree); ?>
提交重置代碼