#javascript #html #.htaccess #url-rewriting #navbar
#javascript #HTML #.htaccess #url-перезапись #панель навигации
Вопрос:
Я переписал свой URL с https://example.com/post.php?post_id=1amp;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>
Код в стиле.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=1amp;post_url=Title-Goes-Here
RewriteRule ^post/([0-9] )/([0-9a-zA-Z_-] )$ post.php?post_id=$1amp;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]
Ответ №1:
Попробуйте очистить кеши, это обычно работает. Это часто делается в меню разработки (er) вашего браузера.
Комментарии:
1. Все еще не работает! Навигационное меню не сворачивается для этих переписанных URL-адресов, так могут ли какие-либо изменения в JS заставить его работать?