Maison  >  Article  >  développement back-end  >  Meilleures pratiques de classification infinie PHP

Meilleures pratiques de classification infinie PHP

高洛峰
高洛峰original
2017-02-09 09:24:551062parcourir

Classification illimitée

  • est une fonction très courante et nécessaire, presque tous les projets l'ont.

  • Scénarios d'application : listes déroulantes, arborescences, etc.

Types de classification illimités

  • Implémentation front-end (Le framework front-end a généralement été implémenté et il peut être généré tant que le back-end transmet les données au front-end dans le format spécifié)

  • Implémentation back-end(Ce qui suit parle principalement de ce type d'implémentation)

Implémentations infiniment multiples

  • Le premier type (recommandé)

function infiniteSort($data, $showFName, $titleFName, $pidFName = 'pid', $idFName = 'id', $levelFName = 'level', $pid = 0, $level = 0)
{
    $tree = array();

    foreach ($data as $key => $value) {

        if ($value[$pidFName] == $pid) {
            $value[$levelFName] = $level;
            $value[$showFName] = str_repeat('  ', $level) . '|-' . $value[$titleFName];
            $tree[] = $value;
            unset($data[$key]);
            $tempArr = infiniteSort($data, $showFName, $titleFName, $pidFName, $idFName, $level, $value[$idFName], $level + 1);
            if(!empty($tempArr)){
                $tree = array_merge($tree, $tempArr);
            }
        }

    }

    return $tree;
}

Remarque :
1 $data Toutes les données qui ont été trié par asc
2. $showFName Le nom du champ du nom d'affichage (formaté)
3. $titleFName Le nom du champ du titre (non formaté)
2. 🎜>4. $levelFName Nom du champ de niveau
5. $pidFName Nom du champ de l'identifiant parent
6. $idFName Nom du champ de l'identifiant.

  • Le deuxième type (utilisant des variables de référence)

/**
 * 无限级分类
 * @param Array $treeList //接受处理完成数据的数组
 * @param Array $data //数据库里获取的结果集
 * @param String $level //格式化层级字段名
 * @param Int $pid
 * @param Int $count //第几级分类
 */
function tree(&$treeList, &$data, $level, $show_name, $field_name, $field_pid = 'pid', $field_id = 'id', $pid = 0, $count = 0)
{
    foreach ($data as $key => $value) {

        if ($value[$field_pid] == $pid) {
            $value[$level] = $count;
            $value[$show_name] = str_repeat('    ',$count).'|-'.$value[$field_name];
            $treeList[] = $value;
            unset($data[$key]);
            tree($treeList, $data, $level, $show_name, $field_name,$field_pid, $field_id, $value[$field_id], $count+1);
        }

    }
}


Remarque : 1 . $data Toutes les données qui ont été triées par asc

2 Les données de liste de niveau infini renvoyées sont stockées dans $treeList
  • Le. troisième type

    (il y a des restrictions sur l'utilisation de variables statiques : si une requête est appelée deux fois, il y aura des problèmes si vous souhaitez implémenter 2 niveaux de classification infinis, ce n'est donc pas recommandé)
    public function getTree($list, $parent_id, $level=0) {
        //应该是静态的局部变量,这样才能保证,在递归调用时,所有
        //的getTree方法,操作的是一个Tree空间。
        static $tree = array();//保存找到的分类的数组
        //遍历所有分类,通过parent_id判断,哪些是我们正在查找的
        foreach($list as $row) {
            //判断当前所遍历的分类$row, 是否是当前需要查找的子分类
            if($row['pid'] == $parent_id) {
                //找到了一个分类
                //存起来,存哪?
                $row['level'] = $level;
                $tree[] = $row;
                //继续查找当前$row所代表的分类的子分类
                $this->getTree($list, $row['id'], $level+1);
            }
        }
        return $tree;
    }


Remarque : 1. $list Toutes les données qui ont été triées par asc

Classification illimitée
  • est une fonction très courante et nécessaire, presque tous les projets l'ont.
  • Scénarios d'application : listes déroulantes, arborescences, etc.

Types de classification illimités
  • Implémentation front-end

    (Le framework front-end a généralement été implémenté et il peut être généré tant que le back-end transmet les données au front-end dans le format spécifié)
  • Implémentation back-end

    (Ce qui suit parle principalement de ce type d'implémentation)

Implémentations infiniment multiples
  • Le premier type (recommandé)

function infiniteSort($data, $showFName, $titleFName, $pidFName = 'pid', $idFName = 'id', $levelFName = 'level', $pid = 0, $level = 0)
{
    $tree = array();

    foreach ($data as $key => $value) {

        if ($value[$pidFName] == $pid) {
            $value[$levelFName] = $level;
            $value[$showFName] = str_repeat('  ', $level) . '|-' . $value[$titleFName];
            $tree[] = $value;
            unset($data[$key]);
            $tempArr = infiniteSort($data, $showFName, $titleFName, $pidFName, $idFName, $level, $value[$idFName], $level + 1);
            if(!empty($tempArr)){
                $tree = array_merge($tree, $tempArr);
            }
        }

    }

    return $tree;
}


Remarque : 1. 🎜>Toutes les données qui ont été triées par asc
2 , $showFName Affichez le nom du champ du nom (formaté)
3 $titleFName Le nom du champ de. le titre (non formaté)
4. $levelFName Nom du champ de niveau
5. $pidFName Nom du champ de l'identifiant parent
6. 🎜>Nom du champ de l'identifiant

  • Deuxième type (en utilisant des variables de référence)

/**
 * 无限级分类
 * @param Array $treeList //接受处理完成数据的数组
 * @param Array $data //数据库里获取的结果集
 * @param String $level //格式化层级字段名
 * @param Int $pid
 * @param Int $count //第几级分类
 */
function tree(&$treeList, &$data, $level, $show_name, $field_name, $field_pid = 'pid', $field_id = 'id', $pid = 0, $count = 0)
{
    foreach ($data as $key => $value) {

        if ($value[$field_pid] == $pid) {
            $value[$level] = $count;
            $value[$show_name] = str_repeat('    ',$count).'|-'.$value[$field_name];
            $treeList[] = $value;
            unset($data[$key]);
            tree($treeList, $data, $level, $show_name, $field_name,$field_pid, $field_id, $value[$field_id], $count+1);
        }

    }
}
Remarque :

1. $data
a été trié par asc Toutes les données 2. Les données de la liste infinie renvoyées sont stockées dans $treeList

  • Le troisième type

    (il existe des restrictions sur l'utilisation de variables statiques : si une requête est appelée deux fois pour implémenter deux classifications infinies, des problèmes surviendront, ce n'est donc pas recommandé)

Remarque :
    public function getTree($list, $parent_id, $level=0) {
        //应该是静态的局部变量,这样才能保证,在递归调用时,所有
        //的getTree方法,操作的是一个Tree空间。
        static $tree = array();//保存找到的分类的数组
        //遍历所有分类,通过parent_id判断,哪些是我们正在查找的
        foreach($list as $row) {
            //判断当前所遍历的分类$row, 是否是当前需要查找的子分类
            if($row['pid'] == $parent_id) {
                //找到了一个分类
                //存起来,存哪?
                $row['level'] = $level;
                $tree[] = $row;
                //继续查找当前$row所代表的分类的子分类
                $this->getTree($list, $row['id'], $level+1);
            }
        }
        return $tree;
    }
1. $list

est déjà Toutes les données triées par asc

Pour plus d'articles liés aux meilleures pratiques de classification infinie PHP, veuillez payer attention au site PHP 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