您好,登錄后才能下訂單哦!
本篇文章給大家分享的是有關使用php怎么實現無限極分類,小編覺得挺實用的,因此分享給大家學習,希望大家閱讀完這篇文章后可以有所收獲,話不多說,跟著小編一起來看看吧。
第一種方法(數組法)
這種方法其實是先把所有的數據查詢出來,重點在于生成的二維數組
<?php //分類方法 function make_list($parent,$deep = 0){ global $tasks;//申明全局變量 global $strArr;//申明全局變量 $qianzhui = str_repeat(" ",$deep)."|--"; foreach ($parent as $key => $value) { $strArr[] = $qianzhui.$value; if(isset($tasks[$key])){ make_list($tasks[$key],++$deep);//遞歸調用函數 } } } //數據庫連接 $dbc = mysqli_connect("localhost","root","1234","tasks"); //拼接sql語句 $q = "select task_id,parent_id,task from tasks where date_completed = '0000-00-00:00:00:00' order by parent_id,date_added asc"; //執行sql $r = mysqli_query($dbc,$q); //遍歷結果集 while (list($task_id,$parent_id,$task) = mysqli_fetch_array($r,MYSQLI_NUM)) { //組成數組(一級鍵為parent_id,二級鍵為task_id,值為任務內容) $tasks[$parent_id][$task_id] = $task; } //打印數組 echo "<pre>"; print_r($tasks); echo "</pre>"; make_list($tasks[0]); echo "<pre>"; //打印縮進數組 print_r($strArr); echo "</pre>"; ?>
運行結果圖
第二種方法(查表法)
這種方法其實是在一開始只查詢出parent_id=0的所有任務,然后采用遞歸的方式,動態生成查詢條件,然后把每條記錄的task_id又作為task_id,這樣又進行新一輪的查詢,知道查詢結果為空。
<?php function findArr($where = "parent_id = 0",$deep = 0){ $dbc = mysqli_connect("localhost","root","1234","tasks"); global $strArr; $q = "select task_id,parent_id,task from tasks where ".$where." order by parent_id,date_added asc"; $r = mysqli_query($dbc,$q); $qianzhui = str_repeat(" ", $deep)."|--"; while (list($task_id,$parent_id,$task) = mysqli_fetch_array($r,MYSQLI_NUM)) { $strArr[] = $qianzhui.$task; //拼接查詢條件 $where = "parent_id = ".$task_id; //遞歸查詢 findArr($where,++$deep); } } findArr(); //打印縮進數組 echo "<pre>"; print_r($strArr); echo "</pre>"; ?>
php是一個嵌套的縮寫名稱,是英文超級文本預處理語言,它的語法混合了C、Java、Perl以及php自創新的語法,主要用來做網站開發,許多小型網站都用php開發,因為php是開源的,從而使得php經久不衰。
以上就是使用php怎么實現無限極分類,小編相信有部分知識點可能是我們日常工作會見到或用到的。希望你能通過這篇文章學到更多知識。更多詳情敬請關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。