Как построить многоуровневую выпадающую панель начальной загрузки bootstrap 4 при наведении курсора на php pdo? - PullRequest
0 голосов
/ 17 октября 2019

Я пытаюсь интегрировать вложенные категории в загрузочную навигационную панель с выпадающим списком. Я пробовал много разных примеров и делал поиск в Google, но ни один не решил мою проблему. Мое структурированное дерево показывает выпадающие списки, когда я нажимаю на них, ничего не происходит. который должен показывать подкатегории в выпадающем списке.

Вы можете видеть на изображении

https://ibb.co/kMhV2QQ

После многих попыток и изменений кода это то, что у меня есть:

function dynamic_menu($parent_array, $sub_array, $qs_val = "menu", $main_id = "nav", $sub_id = "subnav", $extra_style = "foldout") {
    $menu = "<ul id=\"".$main_id."\" class=\"navbar-nav mr-auto\">\n";
    foreach ($parent_array as $pkey => $pval) {
        if (!empty($pval['count'])) {
            $menu .= "<li class=\"nav-item\"><a href=\"#\" class=\"nav-link dropdown-toggle\" id=\"navbarDropdownMenuLink-333\" data-toggle=\"dropdown\"
          aria-haspopup=\"true\" aria-expanded=\"false\">".$pval['label']."</a>\n";
        } else {
            $menu .= "<li class=\"nav-item dropdown\"><a class=\"nav-link\" href=\"".$pval['link']."\">".$pval['label']."</a></li>\n";
        }
        if (!empty($_REQUEST[$qs_val])) {
            $menu .= "<div class=\"dropdown-menu dropdown-default\" aria-labelledby=\"navbarDropdownMenuLink-333\" id=\"".$sub_id."\">\n";
            foreach ($sub_array as $sval) {
                if ($pkey == $_REQUEST[$qs_val] && $pkey == $sval['parent']) {
                    $menu .= "<a class=\"dropdown-item\" href=\"".rebuild_link($sval['link'], $qs_val, $sval['parent'])."\" target=\"_blank\">".$sval['label']."</a>\n";
                }
            }
            $menu .= "</div>\n";
            $menu .= "</li>\n";
        }
    }
    $menu .= "</ul>\n";
    return $menu;
}

Вот навигационная панель, которую я пытаюсь интегрировать:

  <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css">
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.4.1/jquery.min.js"></script>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js"></script>
  <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js"></script>
  
<!--Navbar -->
<nav class="mb-1 navbar navbar-expand-lg navbar-dark bg-info">
  <a class="navbar-brand" href="#">Navbar</a>
  <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent-333"
    aria-controls="navbarSupportedContent-333" aria-expanded="false" aria-label="Toggle navigation">
    <span class="navbar-toggler-icon"></span>
  </button>
  <div class="collapse navbar-collapse" id="navbarSupportedContent-333">
    <ul class="navbar-nav mr-auto">
      <li class="nav-item active">
        <a class="nav-link" href="#">Home
          <span class="sr-only">(current)</span>
        </a>
      </li>
      <li class="nav-item dropdown">
        <a class="nav-link dropdown-toggle" id="navbarDropdownMenuLink-333" data-toggle="dropdown"
          aria-haspopup="true" aria-expanded="false">Dropdown
        </a>
        <div class="dropdown-menu dropdown-default" aria-labelledby="navbarDropdownMenuLink-333">
          <a class="dropdown-item" href="#">Action</a>
          <a class="dropdown-item" href="#">Another action</a>
          <a class="dropdown-item" href="#">Something else here</a>
        </div>
      </li>
    </ul>
  </div>
</nav>
<!--/.Navbar -->

Вот моя структура sql, если необходимо:

    CREATE TABLE IF NOT EXISTS `dyn_menu` (
  `id` int(11) NOT NULL auto_increment,
  `label` varchar(50) NOT NULL default '',
  `link_url` varchar(100) NOT NULL default '#',
  `parent_id` int(11) NOT NULL default '0',
  PRIMARY KEY  (`id`)
) ENGINE=MyISAM  DEFAULT CHARSET=latin1 AUTO_INCREMENT=13 ;

1 Ответ

0 голосов
/ 02 ноября 2019

Вот лучшее решение, которое я нашел для своего вопроса после многих поисков и проб на множестве разных примеров, и я думаю, что это лучший способ для правильной работы загрузочной навигационной панели.

это многоуровневое меню начальной загрузкина зависании с jquery

и кодами:

function bootstrap_menu($pdo, $parent_id, $level = null) {
//First query to find category id 
        $stmt = $pdo->prepare("SELECT * FROM categories WHERE parent_id =:parent_id");
        $stmt->bindParam(":parent_id", $parent_id, PDO::PARAM_INT);
        $stmt->execute();
//FetchAll as $row to use
        foreach ($stmt->fetchAll() as $row) {
    //Second query to find cildren of main categories
        $sql = $pdo->prepare("SELECT count(*) FROM categories WHERE parent_id =:cat_id");
        $sql->bindParam(":cat_id", $row['cat_id'], PDO::PARAM_INT);
        $sql->execute();
    //Here we check for parent and level valuess 
        if($sql->fetchAll()[0][0] !== '0' && $level !== 0){ 
    //Here we check if category has children if so display dropdown
            echo "<li class=\"nav-item dropdown\">\n";
            echo "<a class=\"nav-link dropdown-toggle\" href=\"".htmlspecialchars($row['seo_url'])."\" id=\"navbarDropdown\" role=\"button\" data-toggle=\"dropdown\"
                    aria-haspopup=\"true\" aria-expanded=\"false\">\n";
            echo $row['cat_name'];
            echo "</a>\n";
            echo "<ul class=\"dropdown-menu\" aria-labelledby=\"navbarDropdown\">\n";
            bootstrap_menu($pdo, $row[0], $level - 1);
            echo "</ul>\n";
            echo "</li>\n";
        }elseif($level == 0){
    //Here we set our actice class $my_class
            $my_class= htmlspecialchars($row['cat_name']);          
            if($my_class== 'Home'){
                echo "<li class=\"nav-item active\">\n";
                echo "<a href=\"".htmlspecialchars($row['seo_url'])."\" class=\"nav-link \">\n";
                echo htmlspecialchars($row['cat_name']);
                echo "</a>\n";
                echo "</li>\n";
            }else{
                echo "<li class=\"nav-item\">\n";
                echo "<a href=\"".htmlspecialchars($row['seo_url'])."\" class=\"nav-link\">\n";
                echo htmlspecialchars($row['cat_name']);
                echo "</a>\n";
                echo "</li>\n";
            }
        }
        else { 
            echo "<li class=\"dropdown-item\">";
            echo "<a href=\"".htmlspecialchars($row['seo_url'])."\" class=\"dropdown-item\">\n";
            echo htmlspecialchars($row['cat_name']);
            echo "</a>\n";
            echo "</li>\n";
        }
        unset($sql);
    }
unset($stmt);
}
...