首页 > 解决方案 > URL重写htaccess后导航栏不折叠

问题描述

我已将我的网址从 https://example.com/post.php?post_id=1&post_url=best-articles-in-the-internet改写 为 https://example.com/post/1/best-articles-in- the-internet 并且还删除了带有 htaccess 的扩展。无论我在哪里重写了 url,导航栏菜单都不会在小屏幕设备/手机中下降/折叠。但在所有原始未更改的 URL 中,导航菜单在手机中完美运行。为什么这会发生在我身上?没有 htaccess 重写,它没有任何问题,但是重写,菜单在手机中不起作用!先感谢您!我在这里包括我的引导菜单代码。

所有文件的标题中的导航代码,

<nav class="navbar navbar-default navbar-fixed-top">
    <div class="container-fluid">
      <!-- Brand and toggle get grouped for better mobile display -->
      <div class="navbar-header">
        <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
          <span class="sr-only">Toggle navigation</span>
          <span class="icon-bar"></span>
          <span class="icon-bar"></span>
          <span class="icon-bar"></span>
        </button>
        <a href="https://example.com/index/"><img src="https://example.com/img/site/Logo.png" alt="mysite Logo"  width="180px" height="54px" > </a>
      </div>
  
      <!-- Collect the nav links, forms, and other content for toggling -->
      <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
        <ul class="nav navbar-nav navbar-right">
          <li><a href="https://example.com/index/"><i class="fa fa-home"></i> Home</a></li>
          <li class="dropdown">
            <a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-haspopup="true" aria-expanded="false"><i class="fa fa-list-alt"></i> Categories<span class="caret"></span></a>
            <ul class="dropdown-menu">
            <?php
              $query = "SELECT * FROM categories ORDER BY cate_id DESC";
              $run =  mysqli_query($con, $query);
              if(mysqli_num_rows($run) > 0){
                while($row = mysqli_fetch_array($run)){
                  $category = ucwords($row['category']);
                  $php_name = $row['php_name'];
                  echo "<li><a href='https://example.com/$php_name/'>$category</a></li>";
                }
              }
              else{
                echo "<li><a href='#'>No Categories Available</a></li>";
              }
            ?>
            </ul>
          </li>
          <li><a href="https://example.com/contact-us/"><i class="fa fa-phone"></i> Contact Us</a></li>
        </ul>
      </div><!-- /.navbar-collapse -->
    </div><!-- /.container-fluid -->
  </nav>

style.css 中的代码

@media only screen and (min-width: 768px) {
    .dropdown:hover .dropdown-menu {
        display: block;
    }

Main.js 中的代码

$('.dropdown-toggle').click(function(e) {
if ($(document).width() > 768) {
  e.preventDefault();

  var url = $(this).attr('href');

     
  if (url !== '#') {
  
    window.location.href = url;
  }

}
});

AOS.init();

htaccess 重写规则

# Turn Rewrite Engine On
RewriteEngine on
# Rewrite for post.php?post_id=1&post_url=Title-Goes-Here
RewriteRule ^post/([0-9]+)/([0-9a-zA-Z_-]+)$ post.php?post_id=$1&post_url=$2 [NC,L]
# Rewrite for index.php?page=1
RewriteRule ^index/page/([0-9]+)$ index.php?page=$1 [NC,L]
# Rewrite for category.php?page=1
RewriteRule ^category/page/([0-9]+)$ category.php?page=$1 [NC,L]
# Rewrite for file extension
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^([^/]+)/$ $1.php
RewriteRule ^([^/]+)/([^/]+)/$ /$1/$2.php
RewriteCond %{REQUEST_FILENAME} !-f
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_URI} !(\.[a-zA-Z0-9]{1,5}|/)$
RewriteRule (.*)$ /$1/ [R=301,L]

标签: javascripthtml.htaccessurl-rewritingnavbar

解决方案


尝试清空缓存,这通常有效。这通常在浏览器的开发(er)菜单中完成。


推荐阅读