溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

php實(shí)現(xiàn)無(wú)限極分類(lèi)的方法

發(fā)布時(shí)間:2021-03-26 09:38:36 來(lái)源:億速云 閱讀:202 作者:小新 欄目:編程語(yǔ)言

小編給大家分享一下php實(shí)現(xiàn)無(wú)限極分類(lèi)的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

php實(shí)現(xiàn)無(wú)限極分類(lèi)的方法:首先創(chuàng)建一個(gè)PHP示例文件;然后編寫(xiě)邏輯代碼;接著從頂層逐級(jí)向下獲取子類(lèi);最后從子類(lèi)開(kāi)始逐級(jí)向上獲取其父類(lèi)即可實(shí)現(xiàn)無(wú)限極分類(lèi)。

PHP實(shí)現(xiàn)無(wú)限極分類(lèi)圖文教程

一般來(lái)說(shuō)實(shí)現(xiàn)無(wú)限極分類(lèi)都是使用遞歸或者迭代的方式,小伙伴們看下本文的實(shí)現(xiàn)方式吧。

1,數(shù)據(jù)庫(kù)設(shè)計(jì):

php實(shí)現(xiàn)無(wú)限極分類(lèi)的方法

php實(shí)現(xiàn)無(wú)限極分類(lèi)的方法

2,代碼:

代碼如下:

/** 
 * @author koma 
 * @todo   PHP無(wú)限極分類(lèi) 
 */ $cn = mysql_connect('localhost', 'root', '') or die(mysql_error()); 
mysql_select_db('t', $cn) or die(mysql_error()); 
mysql_query('set names utf8'); 
 /** 
 * 從頂層逐級(jí)向下獲取子類(lèi) 
 * @param number $pid 
 * @param array $lists 
 * @param number $deep 
 * @return array 
 */ function getLists($pid = 0, &$lists = array(), $deep = 1) { 
    $sql = 'SELECT * FROM category WHERE pid='.$pid; 
    $res = mysql_query($sql); 
    while ( ($row = mysql_fetch_assoc($res)) !== FALSE ) { 
        $row['catename'] = str_repeat('   ', $deep).'|---'.$row['catename']; 
        $lists[] = $row; 
        getLists($row['id'], $lists, ++$deep); //進(jìn)入子類(lèi)之前深度+1         --$deep; 
        //從子類(lèi)退出之后深度-1    
         } 
    return $lists; 
} 
 function displayLists($pid = 0, $selectid = 1) { 
    $result = getLists($pid); 
    $str = '<select>'; 
    foreach ( $result as $item ) { 
        $selected = ""; 
        if ( $selectid == $item['id'] ) { 
            $selected = 'selected'; 
        } 
        $str .= '<option '.$selected.'>'.$item['catename'].'</option>'; 
    } 
    return $str .= '</select>'; 
} /** 
 * 從子類(lèi)開(kāi)始逐級(jí)向上獲取其父類(lèi) 
 * @param number $cid 
 * @param array $category 
 * @return array: 
 */ function getCategory($cid, &$category = array()) { 
    $sql = 'SELECT * FROM category WHERE id='.$cid.' LIMIT 1'; 
    $result = mysql_query($sql); 
    $row = mysql_fetch_assoc($result); 
    if ( $row ) { 
        $category[] = $row; 
        getCategory($row['pid'], $category); 
    } 
    krsort($category); //逆序,達(dá)到從父類(lèi)到子類(lèi)的效果     return $category; 
} 
 function displayCategory($cid) { 
    $result = getCategory($cid); 
    $str = ""; 
    foreach ( $result as $item ) { 
        $str .= '<a href="'.$item['id'].'">'.$item['catename'].'</a>>'; 
    } 
    return substr($str, 0, strlen($str) - 1); 
} 
 echo displayLists(0, 3); 
 echo displayCategory(13);

3,效果圖:

php實(shí)現(xiàn)無(wú)限極分類(lèi)的方法

以上是“php實(shí)現(xiàn)無(wú)限極分類(lèi)的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI