Maison  >  Article  >  développement back-end  >  laravel implémente une classification infinie

laravel implémente une classification infinie

大家讲道理
大家讲道理original
2017-02-22 14:00:544193parcourir

Explication

Tout le monde utilise généralement la récursivité pour implémenter la classification infinie. Nous savons tous que la récursion est très inefficace. Voici un package d'extension Laravel recommandé. etrepat/baum, faites en sorte que votre modèle de données prenne rapidement en charge une structure hiérarchique arborescente infinie, tout en tenant compte de l'efficacité.

Utilisez le modèle d'ensemble imbriqué Baum pour implémenter la classification infinie du modèle Laravel

La documentation officielle du package d'extension a un espace pour l'explication, et l'image ci-dessous est aussi un Exemple simple :

laravel implémente une classification infinie

Description du cas d'utilisation #

Parlons ensuite de quelques exemples de modèles hiérarchiques d'arbres infinis.

Système de balises#

Référence : Laravel Taggable Ajoutez une fonction de balisage à votre modèle. Une balise peut avoir d'innombrables balises enfants, appartenir à une balise parent et avoir plusieurs balises homologues.

Par exemple, l'arborescence des balises ci-dessous :

$tagTree = [
    'name' => 'RootTag',
    'children' => [
        ['name' => 'L1Child1',
            'children' => [
                ['name' => 'L2Child1'],
                ['name' => 'L2Child1'],
                ['name' => 'L2Child1'],
            ]
        ],
        ['name' => 'L1Child2'],
        ['name' => 'L1Child3'],
    ]];

Système de commentaires #

Commentaires imbriqués à l'infini, comme le système de commentaires de NetEase.

laravel implémente une classification infinie

Laravel a une extension de commentaire qui prend en charge l'imbrication infinie, voir Slynova-Org/laravel-commentable.

Modèle de données "Barre de navigation"#

L'arrière-plan de l'administrateur doit fournir une fonction de personnalisation de la "barre de navigation" et une barre de navigation arborescente.

laravel implémente une classification infinie

Baum#

etrepat/baum intégré permet rapidement à votre modèle de données de prendre en charge la structure hiérarchique arborescente Infinitus tout en prenant en compte l'efficacité.

Ensuite, nous parlerons de la façon d'intégrer.

1. Installation de Composer#

composer require "baum/baum:~1.1"

2. Ajouter un fournisseur#

Modifiez le fichier config/app.php et ajoutez : providers array>

'Baum\Providers\BaumServiceProvider',
Ce fournisseur de services enregistre deux commandes :

, artisan baum. artisan  baum.install

3. Créez la migration#

et installez-la sur le modèle de données existant :

php artisan baum:install MODEL
Exécutez ensuite

php artisan migrate
sur les champs de migration Introduction#

  • parent_id : l'identifiant du nœud parent

  • lft : la valeur de l'index gauche

  • rgt : Valeur d'index à droite

  • profondeur : Niveau de profondeur

Ce qui suit est un exemple :

class Category extends Migration {
  public function up() {
    Schema::create('categories', function(Blueprint $table) {
      $table->increments('id');

         // 这四行代码
      $table->integer('parent_id')->nullable();
      $table->integer('lft')->nullable();
      $table->integer('rgt')->nullable();
      $table->integer('depth')->nullable();

      $table->string('name', 255);

      $table->timestamps();
    });
  }}
4. Configurez le modèle de données #

Hériter BaumNode

class Category extends Baum\Node {}
Après l'héritage, ces propriétés peuvent être remplacées :

class Category extends Baum\Node {
  protected $table = 'categories';

  // 'parent_id' column name
  protected $parentColumn = 'parent_id';

  // 'lft' column name
  protected $leftColumn = 'lidx';

  // 'rgt' column name
  protected $rightColumn = 'ridx';

  // 'depth' column name
  protected $depthColumn = 'nesting';

  // guard attributes from mass-assignment
  protected $guarded = array('id', 'parent_id', 'lidx', 'ridx', 'nesting');}
L'intégration est réussie.

Utiliser

$root = Tag::create(['name' => 'Root']);

// 创建子标签
$child1 = $root->children()->create(['name' => 'Child1']);

$child = Tag::create(['name' => 'Child2']);
$child->makeChildOf($root);

// 批量构建树
$tagTree = [
    'name' => 'RootTag',
    'children' => [
        ['name' => 'L1Child1',
            'children' => [
                ['name' => 'L2Child1'],
                ['name' => 'L2Child1'],
                ['name' => 'L2Child1'],
            ]
        ],
        ['name' => 'L1Child2'],
        ['name' => 'L1Child3'],
    ]
];

Tag::buildTree($tagTree);


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