javascript - 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]
解决方案
尝试清空缓存,这通常有效。这通常在浏览器的开发(er)菜单中完成。
推荐阅读
- php - 如何为codeigniter中的特定列数据赋予颜色?
- css - 已正确连接,但无法正常工作 - CSS 切换
- azure - Azure - 无法在事件上运行 LogicApp
- python - 使用 cv2.bitwise 时颜色错误
- java - 返回 Try 的方法是否允许抛出?
- node.js - Heroku 无法连接到 MongoDB Atlas
- regex - Kotlin,无法匹配正则表达式模式
- authentication - 使用 ServiceStack 和更多提供商进行身份验证
- python - 比较具有给定容差范围的两个数据帧
- python - 减去pandas DataFrame中特定于参数的列均值