PHP에서 개발된 분류 기술...LOGIN

PHP에서 개발된 분류 기술은 foreach 루프를 사용하여 분류 기능을 구현합니다.

분류란 무엇인가요? Windows에서 새 폴더를 만드는 것과 마찬가지로 새 폴더 아래에 새 폴더를 만들 수 있습니다. 이는 분류의 경우에도 마찬가지입니다. - 카테고리는 하위 카테고리로 나눌 수 있습니다. . . . . .

그렇다면 PHP는 분류를 어떻게 구현합니까? 다양한 카테고리를 하나씩 나열하는 방법은 무엇입니까?

이 장에서는 foreach 루프를 사용하여 분류 기능을 구현하는 방법을 소개합니다.

먼저 분류 배열을 만듭니다:

<?php
$categories = array(
  array('id'=>1,'name'=>'电脑','pid'=>0),
  array('id'=>2,'name'=>'手机','pid'=>0),
  array('id'=>3,'name'=>'笔记本','pid'=>1),
  array('id'=>4,'name'=>'台式机','pid'=>1),
  array('id'=>5,'name'=>'智能机','pid'=>2),
  array('id'=>6,'name'=>'功能机','pid'=>2),
  array('id'=>7,'name'=>'超级本','pid'=>3),
  array('id'=>8,'name'=>'游戏本','pid'=>3),
);
?>

여기에는 정렬 ID, 분류 이름 이름, 분류 pid의 3개 필드가 있습니다.

목표는 이를 다음 구조로 변환하는 것입니다.


<?php
array(
      //1对应$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'=>'台式机',
                            'pid'=>1,
                            ),
          ),
      ),
      2 => array(
            'id'=>2,
            'name'=>'手机',
            'pid'=>0,
            'children' =>array(
                              array(
                                'id'=>5,
                                'name'=>'智能机',
                                'pid'=>2,
                              ),
                              array(
                                'id'=>6,
                                'name'=>'功能机',
                                'pid'=>2,
                              ),
            ),
      ),
      );
?>

구현 과정:

QQ图片20161102150838.png빈 배열 만들기

<?php
$tree = array();
?>

첫 번째 단계는 모든 카테고리 ID를 배열 키로 사용하고 하위 유닛을 만드는 것입니다.

<?php
foreach($categories as $category){
  $tree[$category['id']] = $category;
  $tree[$category['id']]['children'] = array();
}
?>

두 번째 단계는 참조를 사용하여 다음과 같이 상위 클래스 하위 배열에 각 카테고리를 추가하는 것입니다. 한 번의 순회로 트리 구조를 형성할 수 있습니다.


<?php
foreach ($tree as $key=>$value) {
  if ($value['pid'] != 0) {
    $tree[$value['pid']]['children'][] = $tree[$key];
  }
}
?>

마지막으로 print_r();을 사용하여 인쇄합니다


<?php
print_r($tree);
?>

장점: 관계가 명확하고 상하 관계를 수정하기 쉽습니다.

단점: 처리에 PHP를 사용하면 카테고리 수가 많으면 효율성도 떨어집니다.
다음 섹션

<?php header("content-type:text/html;charset=utf-8"); //利用两个foreach来实现分类功能 /* 1. 构建字段 字段名 字段类型 备注 默认值 id int 主键 auto-increment name varchar 分类名称 pid int 父类id 0 */ //先来构建一个原始数组 $categories = array( array('id'=>1,'name'=>'电脑','pid'=>0), array('id'=>2,'name'=>'手机','pid'=>0), array('id'=>3,'name'=>'笔记本','pid'=>1), array('id'=>4,'name'=>'台式机','pid'=>1), array('id'=>5,'name'=>'智能机','pid'=>2), array('id'=>6,'name'=>'功能机','pid'=>2), array('id'=>7,'name'=>'超级本','pid'=>3), array('id'=>8,'name'=>'游戏本','pid'=>3), ); array( //1对应$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'=>'台式机', 'pid'=>1, ), ), ), 2 => array( 'id'=>2, 'name'=>'手机', 'pid'=>0, 'children' =>array( array( 'id'=>5, 'name'=>'智能机', 'pid'=>2, ), array( 'id'=>6, 'name'=>'功能机', 'pid'=>2, ), ), ), ); //处理过程 $tree = array(); //第一步,将所有的分类id作为数组key,并创建children单元 foreach($categories as $category){ $tree[$category['id']] = $category; $tree[$category['id']]['children'] = array(); } //第二步,利用引用,将每个分类添加到父类children数组中,这样一次遍历即可形成树形结构。 foreach ($tree as $key=>$value) { if ($value['pid'] != 0) { $tree[$value['pid']]['children'][] = $tree[$key]; } } print_r($tree); ?>
코스웨어