>  기사  >  백엔드 개발  >  PHP 무한 분류 모범 사례

PHP 무한 분류 모범 사례

高洛峰
高洛峰원래의
2017-02-09 09:24:551018검색

무제한 분류

  • 는 매우 일반적이고 필요한 기능으로 거의 모든 프로젝트에 있습니다.

  • 적용 시나리오: 드롭다운 목록, 트리 목록 등

분류 유형 무제한

  • 프런트엔드 구현 (프론트엔드 프레임워크는 일반적으로 구현되어 있으며, 백엔드에서 지정된 형식으로 프런트엔드에 데이터를 전송하면 생성 가능)

  • 백엔드 구현(다음에서는 주로 이러한 구현에 대해 설명합니다.)

무한 다중 구현

  • 첫 번째 유형(권장)

function infiniteSort($data, $showFName, $titleFName, $pidFName = 'pid', $idFName = 'id', $levelFName = 'level', $pid = 0, $level = 0)
{
    $tree = array();

    foreach ($data as $key => $value) {

        if ($value[$pidFName] == $pid) {
            $value[$levelFName] = $level;
            $value[$showFName] = str_repeat('  ', $level) . '|-' . $value[$titleFName];
            $tree[] = $value;
            unset($data[$key]);
            $tempArr = infiniteSort($data, $showFName, $titleFName, $pidFName, $idFName, $level, $value[$idFName], $level + 1);
            if(!empty($tempArr)){
                $tree = array_merge($tree, $tempArr);
            }
        }

    }

    return $tree;
}

참고:
1. $data 정렬된 모든 데이터 by asc
2. $showFName 제목 필드 이름(형식 있음)
3. $titleFName 제목 필드 이름(형식 없음)
4. $levelFName 레벨 필드 이름
5. $pidFName 상위 ID의 필드 이름
6. $idFName ID의 필드 이름

  • 두 번째 유형(참조 변수 사용)

/**
 * 无限级分类
 * @param Array $treeList //接受处理完成数据的数组
 * @param Array $data //数据库里获取的结果集
 * @param String $level //格式化层级字段名
 * @param Int $pid
 * @param Int $count //第几级分类
 */
function tree(&$treeList, &$data, $level, $show_name, $field_name, $field_pid = 'pid', $field_id = 'id', $pid = 0, $count = 0)
{
    foreach ($data as $key => $value) {

        if ($value[$field_pid] == $pid) {
            $value[$level] = $count;
            $value[$show_name] = str_repeat('    ',$count).'|-'.$value[$field_name];
            $treeList[] = $value;
            unset($data[$key]);
            tree($treeList, $data, $level, $show_name, $field_name,$field_pid, $field_id, $value[$field_id], $count+1);
        }

    }
}

참고:
1, $data All asc
2 로 정렬된 데이터, 반환된 무한 목록 데이터는 $treeList

  • 세 번째 유형 에 저장됩니다(제한 사항 있음). 정적 변수 사용 시: 2 무한 분류를 달성하기 위해 요청을 두 번 호출하면 문제가 발생하므로 권장하지 않습니다)

    public function getTree($list, $parent_id, $level=0) {
        //应该是静态的局部变量,这样才能保证,在递归调用时,所有
        //的getTree方法,操作的是一个Tree空间。
        static $tree = array();//保存找到的分类的数组
        //遍历所有分类,通过parent_id判断,哪些是我们正在查找的
        foreach($list as $row) {
            //判断当前所遍历的分类$row, 是否是当前需要查找的子分类
            if($row['pid'] == $parent_id) {
                //找到了一个分类
                //存起来,存哪?
                $row['level'] = $level;
                $tree[] = $row;
                //继续查找当前$row所代表的分类的子分类
                $this->getTree($list, $row['id'], $level+1);
            }
        }
        return $tree;
    }

참고:
$list 모든 데이터를 asc로 정렬

무제한 분류

  • 는 매우 일반적이고 필요한 기능으로, 거의 모든 프로젝트에서 그것.

  • 적용 시나리오: 드롭다운 목록, 트리 목록 등

분류 유형 무제한

  • 프런트엔드 구현 (프론트엔드 프레임워크는 일반적으로 구현되어 있으며, 백엔드에서 지정된 형식으로 프런트엔드에 데이터를 전송하면 생성 가능)

  • 백엔드 구현(다음에서는 주로 이러한 구현에 대해 설명합니다.)

무한 다중 구현

  • 첫 번째 유형(권장)

function infiniteSort($data, $showFName, $titleFName, $pidFName = 'pid', $idFName = 'id', $levelFName = 'level', $pid = 0, $level = 0)
{
    $tree = array();

    foreach ($data as $key => $value) {

        if ($value[$pidFName] == $pid) {
            $value[$levelFName] = $level;
            $value[$showFName] = str_repeat('  ', $level) . '|-' . $value[$titleFName];
            $tree[] = $value;
            unset($data[$key]);
            $tempArr = infiniteSort($data, $showFName, $titleFName, $pidFName, $idFName, $level, $value[$idFName], $level + 1);
            if(!empty($tempArr)){
                $tree = array_merge($tree, $tempArr);
            }
        }

    }

    return $tree;
}

참고:
1.$data asc로 정렬된 모든 데이터
2.$ showFName 이름의 필드 이름 표시(형식 지정)
3. $titleFName 제목의 필드 이름 (형식 없음)
4. $levelFName 레벨 필드 이름
5. $pidFName 상위 ID의 필드 이름
6. id의 필드 이름

  • 두 번째 유형(참조 변수 사용)

/**
 * 无限级分类
 * @param Array $treeList //接受处理完成数据的数组
 * @param Array $data //数据库里获取的结果集
 * @param String $level //格式化层级字段名
 * @param Int $pid
 * @param Int $count //第几级分类
 */
function tree(&$treeList, &$data, $level, $show_name, $field_name, $field_pid = 'pid', $field_id = 'id', $pid = 0, $count = 0)
{
    foreach ($data as $key => $value) {

        if ($value[$field_pid] == $pid) {
            $value[$level] = $count;
            $value[$show_name] = str_repeat('    ',$count).'|-'.$value[$field_name];
            $treeList[] = $value;
            unset($data[$key]);
            tree($treeList, $data, $level, $show_name, $field_name,$field_pid, $field_id, $value[$field_id], $count+1);
        }

    }
}
참고:

1. $data
오름차순으로 정렬된 모든 데이터2. 반환된 무한 수준 목록 데이터는 $treeList

  • 에 저장됩니다. 세 번째 유형 (정적 변수 사용에 제한이 있음: 한 번의 요청으로 호출하는 경우 두 개의 무한 수준 분류를 두 번 구현하면 문제가 발생하므로 권장하지 않음)

    public function getTree($list, $parent_id, $level=0) {
        //应该是静态的局部变量,这样才能保证,在递归调用时,所有
        //的getTree方法,操作的是一个Tree空间。
        static $tree = array();//保存找到的分类的数组
        //遍历所有分类,通过parent_id判断,哪些是我们正在查找的
        foreach($list as $row) {
            //判断当前所遍历的分类$row, 是否是当前需要查找的子分类
            if($row['pid'] == $parent_id) {
                //找到了一个分类
                //存起来,存哪?
                $row['level'] = $level;
                $tree[] = $row;
                //继续查找当前$row所代表的分类的子分类
                $this->getTree($list, $row['id'], $level+1);
            }
        }
        return $tree;
    }
참고 :

1. $list
모든 데이터는 asc로 정렬되었습니다.

PHP 무한 분류 모범 사례와 관련된 더 많은 기사를 보려면 다음을 참고하세요. PHP 중국어 웹사이트!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.