>백엔드 개발 >PHP 문제 >PHP 무한 분류 배열을 넣는 방법

PHP 무한 분류 배열을 넣는 방법

王林
王林원래의
2023-05-07 18:10:07519검색

웹 개발에서는 다양한 분류 체계가 널리 사용되며, 인피니투스 분류는 일반적인 분류 방법 중 하나입니다. 인피니투스 분류는 분류 체계에서 분류 수준의 수를 제한하지 않는 분류 방법이므로 배열 구조에 특별한 처리가 필요합니다.

php 언어는 웹 개발에 자주 사용됩니다. PHP 무한 분류 배열 배치 방법에 대해 논의해 보겠습니다.

  1. 재귀적 방법

재귀적 방법은 PHP Infinitus 범주형 배열에서 가장 일반적으로 사용되는 방법입니다. 이는 범주형 데이터를 구성하기 위해 함수의 재귀 호출을 사용합니다.

재귀적 방법은 다음과 같이 작성됩니다.

/**
 * 无限极分类
 * @param array $data         分类数据
 * @param int $pid            父ID
 * @param int $level          层级数
 * @return array              分类数组
 */
function getTree($data, $pid = 0, $level = 0) {
    $tree = [];
    foreach ($data as $val) {
        if ($val['parent_id'] == $pid) {
            $val['level'] = $level;
            $val['children'] = getTree($data, $val['id'], $level + 1);
            $tree[] = $val;
        }
    }
    return $tree;
}

위 코드에서 getTree 함수는 세 가지 매개변수, 즉 분류 데이터 $data, 상위 ID $pid 및 레벨 수 $level을 받습니다. 이 함수는 먼저 $tree 배열을 생성한 후 분류 데이터를 반복하여 현재 분류 ​​항목의 상위 ID가 $pid와 같으면 $tree 배열에 추가됩니다. 각 분류 항목은 현재 레벨 번호를 나타내는 레벨 속성을 추가합니다. 동시에 getTree 함수는 하위 카테고리 항목도 동일한 방식으로 처리될 수 있도록 하위 카테고리 배열을 매개변수로 전달하여 자신을 재귀적으로 호출합니다.

  1. Loop 방법

Loop 방법은 PHP Infinitus 분류 배열의 또 다른 처리 방법으로 주로 루프 중첩을 통해 분류된 데이터의 구성을 구현합니다.

루프 메소드는 다음과 같이 작성됩니다.

/**
 * 无限极分类
 * @param array $data         分类数据
 * @return array              分类数组
 */
function getTree($data) {
    $tree = [];
    $node = [];
    foreach ($data as $val) {
        $node[$val['id']] = $val;
    }
    foreach ($node as $key => &$val) {
        if (isset($node[$val['parent_id']])) {
            $node[$val['parent_id']]['children'][] = &$val;
        } else {
            $tree[] = &$val;
        }
    }
    return $tree;
}

위 코드에서 getTree 함수는 분류된 데이터를 나타내는 $data 매개변수를 받습니다. 이 함수는 먼저 $tree 배열과 $node 배열을 생성하고 $data 데이터를 $node 배열에 넣습니다. 그런 다음 foreach 루프는 $node 배열을 순회합니다. 현재 범주 항목의 상위 ID가 $node 배열에 있으면 현재 범주 항목이 상위 범주 항목의 하위 배열에 추가됩니다.

$node 배열의 요소들은 카테고리 ID에 따라 저장되므로, 처리할 카테고리 항목을 순회하지 않았다면 해당 카테고리 항목이 최상위 카테고리라는 의미이므로 해당 카테고리 항목을 직접 처리할 수 있습니다. $tree 배열에 추가되었습니다. 함수는 최종적으로 무한 범주형 배열인 $tree 배열을 반환합니다.

결론

위는 PHP 무한 분류 배열을 처리하는 두 가지 방법입니다. 재귀 방법이 더 간단하고 루프 방법이 더 유연합니다. 재귀적 방법은 재귀적인 함수 호출을 사용하기 때문에 지나치게 길거나 많은 양의 데이터를 접할 때 호출 스택 오버플로와 같은 문제가 발생하는 반면, 루프 방법은 많은 양의 데이터를 더 잘 처리할 수 있습니다. 사용하는 동안 실제 개발 요구 사항에 따라 적합한 방법을 선택할 수 있습니다.

위 내용은 PHP 무한 분류 배열을 넣는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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