재귀 함수를 작성할 때 일부 정적 변수를 캐싱하고 정의하여 이전 실행 결과를 저장할 수 있습니다. 다중 프로그램 실행 효율성은 다음과 같습니다. 먼저 데이터베이스로 이동하여 데이터를 가져옵니다. 이를 배열에 넣은 다음 데이터를 트리 모양의 배열로 변환하고 마지막으로 이 트리 모양의 배열을 HTML 코드로 변환합니다. 아래 예시를 살펴보겠습니다
제 기술 사이트 중 하나가 주로 기사이고, 일부 기사가 시리즈로 구성되어 있기 때문에 이러한 기사를 분류하여 동일한 카테고리에 넣고 싶습니다.
데이터베이스는 잘 설계되어 있으므로 id와 fatherid를 사용하여 분류하면 됩니다. fatherid는 상위 카테고리를 나타내며 기사의 ID이고 id는 기사의 고유 ID입니다. 레벨은 제한되지 않으며 두 가지 수준일 수 있습니다. 또는 세 가지 수준. fatherid 0은 최상위 기사를 나타냅니다.
php 코드, 주로 재귀적
function category_tree($fatherid){ //require_once("mysql_class/config.inc.php"); //require_once("mysql_class/Database.class.php"); $db = new Database(DB_SERVER, DB_USER, DB_PASS, DB_DATABASE); $db->connect(); $sql = "SELECT id,title,url FROM ".TABLE_TASK." WHERE fatherid=$fatherid and ispublic=1 order by id asc"; $articles = $db->query($sql); $db->close(); while ($record = $db->fetch_array($articles)){ $i = 0; if ($i == 0){ if($fatherid==0){ echo '<ul class="article-list-no-style border-bottom">'; }else{ echo '<ul class="article-list-no-style">'; } } if($fatherid==0){ echo '<li><span class="glyphicon glyphicon-log-in" aria-hidden="true" id="han'.$record['id'].'"> </span> <a href="'.$record['url'].'" target="_blank">' . $record['title'].'</a>'; }else{ echo '<li><span class="glyphicon glyphicon-chevron-right" aria-hidden="true"> </span> <a href="'.$record['url'].'" target="_blank">' . $record['title'].'</a>'; } category_tree($record['id']); echo '</li>'; $i++; if ($i > 0){ echo '</ul>'; } } }
Call:
category_tree(0) //先提取最顶层文章
Summary: 위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되기를 바랍니다.
관련 권장 사항:
PHP의 정적 키워드 정의, 후기 바인딩 및 self 키워드와의 차이점
무엇인지에 대한 간략한 소개 PHP Magic 방식으로 제공
위 내용은 PHP는 재귀를 기반으로 기사 트리를 생성합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!