web前端三大主流框架 PHP無(wú)限級(jí)分類(lèi)?
PHP無(wú)限級(jí)分類(lèi)?問(wèn)題太普遍了。讓我給你一個(gè)無(wú)限分類(lèi)數(shù)據(jù)處理的解決方案。表結(jié)構(gòu)id int主鍵FID int parent id,頂級(jí)分類(lèi)的FID設(shè)置為0,另一級(jí)分類(lèi)的FID值是其父分類(lèi)的idname
PHP無(wú)限級(jí)分類(lèi)?
問(wèn)題太普遍了。讓我給你一個(gè)無(wú)限分類(lèi)數(shù)據(jù)處理的解決方案。表結(jié)構(gòu)id int主鍵FID int parent id,頂級(jí)分類(lèi)的FID設(shè)置為0,另一級(jí)分類(lèi)的FID值是其父分類(lèi)的idname char classification name。如果要顯示整個(gè)分類(lèi)列表,則讀取整個(gè)表以形成一個(gè)數(shù)組$list,其結(jié)構(gòu)為($row=mysqlfetchAssoc($RET)){If(!Isset)$list[$row[“FID”
])$list[$RET[“FID”]=array()$list[$RET[“FID”
[$RET[“ID”]=$row}輸出時(shí),可以使用遞歸將其轉(zhuǎn)換為JSON,并使用js生成樹(shù)菜單,這也非常容易控制。如果查詢(xún)某個(gè)子類(lèi)別下的某個(gè)類(lèi)別,查詢(xún)很簡(jiǎn)單,更不用說(shuō)
初始化數(shù)據(jù)顯示樹(shù)結(jié)構(gòu),用遞歸的方式得到無(wú)限分類(lèi)數(shù)組,用引用無(wú)限分類(lèi)
遞歸很容易理解啊,一般來(lái)說(shuō),是用階乘來(lái)開(kāi)始的。
無(wú)級(jí)分類(lèi)算法是一種典型的遞歸運(yùn)算。但在實(shí)際開(kāi)發(fā)中,通常采用偽無(wú)級(jí)分類(lèi)。當(dāng)分類(lèi)層次多、分類(lèi)節(jié)點(diǎn)多時(shí),無(wú)級(jí)分類(lèi)效率低。因此,作為學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)的算法,需要學(xué)習(xí)無(wú)級(jí)分類(lèi)的算法。如果是實(shí)際開(kāi)發(fā),最好采用偽無(wú)級(jí)分類(lèi)。