Supposons que les champs du tableau des données comptables dans la base de données soient : id, code, name, islast. Il s'agit de la clé primaire à incrémentation automatique, du code du compte, du nom du compte et s'il s'agit du compte de dernier niveau (« 1 » indique le compte de dernier niveau). Ici, la récursivité est utilisée dans la couche modèle de Thinkphp pour construire les données requises par ComboTree. Le code et les annotations sont les suivants :
AccountModel = ->field('id,code,name,islast')->( & = (['code'( == 3['pid'] = 0['pid'] = (['code'],0,-2 ->createTree( createSubTree(, = ( =>(['pid'] == = 'id' => ['id'], 'text'=>['name'], 'state'=>(['islast'] != 1)?'closed':'open'(['islast'] != 1 = ->createSubTree(,['code'(!(['children'] = (, createTree( = ( => (['pid'] == 0 = 'id' => ['id'], 'text'=>['name'], 'state'=>'closed' = ->createSubTree(,['code'(!(['children'] = [] =
Données similaires à celles ci-dessus (telles que départements, régions, etc.) doivent être construits. En principe, des fonctions similaires peuvent être obtenues en modifiant simplement le code du menu arborescent.
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!