Maison >développement back-end >tutoriel php >thinkPHP implémente une méthode de boucle récursive des colonnes et de sortie à l'infini selon la structure arborescente

thinkPHP implémente une méthode de boucle récursive des colonnes et de sortie à l'infini selon la structure arborescente

不言
不言original
2018-05-05 15:01:232914parcourir

Cet article présente principalement la méthode de thinkPHP pour implémenter des colonnes de boucles récursives et sortir à l'infini selon la structure arborescente.Cela implique des compétences telles que la requête de base de données thinkPHP, la traversée de tableaux et le fonctionnement de chaînes.

L'exemple de cet article décrit comment thinkPHP implémente des colonnes de boucles récursives et les génère à l'infini selon la structure arborescente. Partagez-le avec tout le monde pour votre référence, les détails sont les suivants :

Ici, nous utilisons la colonne de boucle récursive thinkphp pour afficher à l'infini selon la structure arborescente et l'enregistrer sous forme de tableau, ce qui est pratique pour l'appel de modèles

Le code spécifique est le suivant :

private function categoryTree($parentid,$level)
//因为是本类中使用所以定于为私有函数
{
$Category= D('Category');
$result = $Category->where("`parentid`=".$parentid)->order("listorder desc,catid desc")->select();
if($result)
{
$count=count($result);//当前子栏目个数
$level++;//子栏目层级
foreach($result as $v)
{
$index++;
if($count==$index) $step="└─";
else $step="├─";
$step.=str_repeat('  ',$level-1);
$nbsp=str_repeat('   ',$level-1);
$nstr=$nbsp.$step;
if($parentid==0) $nstr='';
$v['step']=$nstr;
$newData[$v['catid']]=$v;
//echo $nstr.$v[&#39;catname&#39;]."<br />";
if($v[&#39;child&#39;]==1)//如果有子栏目
{
$newData=$newData+$this->categoryTree($v[&#39;catid&#39;],$level);
}
}
}
return $newData;
}

Les colonnes récursives php sont enregistrées sous forme de tableaux

Recommandations associées :

thinkPHP implémente la méthode de requête de correspondance floue multi-champs

thinkphp implémente le téléchargement et le téléchargement de fichiers

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn