👺
Cheatsheet
  • 👋My cheatsheet
  • 🐘PHP
    • Тернарные операторы
    • Замыкания в PHP
    • Таблица сравнения типов PHP
  • 🟨JS
    • JS cheat sheet
    • Тернарные операторы || ?? &&
    • Таблица сравнения типов JS
    • Область видимости в JS
    • Перебор объектов через for(key in obj)
    • Доступ к свойству через переменную []
    • this в JS
    • Конструктор, оператор "new"
    • bind привязка контекста (this)
    • Замыкания в JS ...
  • ❤️Laravel
    • Laravel websockets
    • Загрузка файлов и пути к ним
    • Vite сборка изображений
    • Vite сборка CSS и JS
    • Vite подключение jQuery
    • Vite подключение Bootstrap
    • Laravel AJAX (with jQuery)
    • Дерево категорий Laravel
    • Laravel + CK-Editor + El FInder
    • Laravel deploy
    • Laravel фасады и сервис провайдеры
    • Отношения
      • Один-к-Одному
      • Один-ко-Многим
      • Многие-ко-Многим
      • Полиморфные отношения
    • Laravel cheatsheet (MAIN)
    • Laravel cheatsheet (BIG)
      • Artisan
      • Auth
      • Blade
      • Cache
      • Composer
      • Config
      • Container
      • Cookie
      • DB
      • Environment
      • Event
      • Eloquent Model
      • File
      • Form
      • HTML
      • Helper
      • Input
      • Lang
      • Log
      • Mail
      • Pagination
      • Queue
      • Redirect
      • Request
      • Response
      • Route
      • SSH
      • Schema
      • Security
      • Session
      • String
      • URL
      • UnitTes
      • Validation
      • View
    • Laravel cheatsheet (BIG PLAIN)
  • 📕PDO
    • SELECT
    • WHERE
    • INSERT
    • UPDATE
    • DELETE
    • JOIN
    • GROUP BY
    • Дерево
    • Дерево ООП
    • Дерево в массив
  • 🐋Docker
    • Docker hub push
    • Docker offline
  • 🥤Gulp
  • 🌊jQuery
  • 🪄Composer
  • 4️⃣Composer PSR-4
  • 🍥RegEx
  • 🐙Git
  • 🧑‍💻Node js
  • 🛍️PHPStorm
  • 💻Zsh
  • 🤖Arduino
Powered by GitBook
On this page
  1. PDO

Дерево ООП

class Categories {

    private $db;
    private $treeStr = '';
    private $data;

    public function __construct(){
        $this->connect();
    }

    public function connect(){ // инициализируем соединение с БД
        $this->db = new PDO("mysql:host=mysql;dbname=php-test;charset=utf8","root","root");
    }

    public function fetch(){ // выбираем всё из таблицы и складывает в массив
        $this->data = $this->db->query("SELECT * FROM categories")->fetchAll(PDO::FETCH_ASSOC);
    }

    public function makeTree($p_id = 0){ // рекурсивная функция, которвя строит список в виде дерева, принимает p_id
        foreach ($this->data as $item){ // переберает весь массив каждый раз
            if ($item['p_id'] == $p_id){ // если p_id эллемента массива соответствует запрошенному p_id в аргументе, то сторит часть списка и рекурсивно открывает функцию makeTree() и передаёт ей id нынешнего элемента массива, который будет принят функцией как p_id
                $this->treeStr .= '<ul>';
                $this->treeStr .= '<li>';
                $this->treeStr .= $item['name'];
                $this->treeStr .= '</li>';
                $this->makeTree($item['id']);
                $this->treeStr .= '</ul>';
            }
        }
    }

    public function showTree(){
        echo $this->treeStr; // выводит строку с созданым списком дерева категорий
    }

}

$categories = new Categories();

$categories->fetch();
$categories->makeTree();
$categories->showTree();

Last updated 2 years ago

📕