Я не понимаю, я сделал навигационную панель, используя jQuery mobile, как описано на их веб-сайте: https://demos.jquerymobile.com/1.4.5/navbar/
И он отлично работает, когда я не ставлю href в элементах неупорядоченного списка (нажатые элементы навигационной панели становятся активными):
<link rel="stylesheet" href="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css" />
<script src="https://code.jquery.com/jquery-1.11.1.min.js"></script>
<script src="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js"></script>
<div id="menu">
<div data-role="navbar">
<ul>
<li><a href="" class="contentUpdate" id="1"><i class="fas fa-swimmer"></i>Swim</a></li>
<li><a href="" class="contentUpdate" id="2"><i class="fas fa-biking"></i>Cycle</a></li>
<li><a href="" class="contentUpdate" id="3"><i class="fas fa-running"></i>Run</a></li>
</ul>
</div>
<!-- /navbar -->
</div>
Однако, когда я помещаю ссылку на другой div в href (я создаю веб-страницу, на которой при нажатии на элемент панели навигации содержимое изменяется) активный класс больше не активируется при нажатии.
<link rel="stylesheet" href="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css" />
<script src="https://code.jquery.com/jquery-1.11.1.min.js"></script>
<script src="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js"></script>
<div id="menu">
<div data-role="navbar">
<ul>
<li><a href="#swim" class="contentUpdate" id="1"><i class="fas fa-swimmer"></i>Swim</a></li>
<li><a href="#cycle" class="contentUpdate" id="2"><i class="fas fa-biking"></i>Cycle</a></li>
<li><a href="#run" class="contentUpdate" id="3"><i class="fas fa-running"></i>Run</a></li>
</ul>
</div>
<!-- /navbar -->
</div>
Я попытался добавить класс к элементам с jQuery, но это не сработало. Если я введу следующий код, первый элемент не станет активным при нажатии:
$("#1").click(function() {
$("#1").addClass("ui-btn-active");
});
<link rel="stylesheet" href="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css" />
<script src="https://code.jquery.com/jquery-1.11.1.min.js"></script>
<script src="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js"></script>
<div id="menu">
<div data-role="navbar">
<ul>
<li><a href="#swim" class="contentUpdate" id="1"><i class="fas fa-swimmer"></i>Swim</a></li>
<li><a href="#cycle" class="contentUpdate" id="2"><i class="fas fa-biking"></i>Cycle</a></li>
<li><a href="#run" class="contentUpdate" id="3"><i class="fas fa-running"></i>Run</a></li>
</ul>
</div>
<!-- /navbar -->
</div>
Однако я знаю, что это работает, потому что если я введу следующий код, два других элемента изменятся на активный класс:
$("#1").click(function() {
$("#1").addClass("ui-btn-active");
$("#2").addClass("ui-btn-active");
$("#3").addClass("ui-btn-active");
});
<link rel="stylesheet" href="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css" />
<script src="https://code.jquery.com/jquery-1.11.1.min.js"></script>
<script src="https://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js"></script>
<div id="menu">
<div data-role="navbar">
<ul>
<li><a href="#swim" class="contentUpdate" id="1"><i class="fas fa-swimmer"></i>Swim</a></li>
<li><a href="#cycle" class="contentUpdate" id="2"><i class="fas fa-biking"></i>Cycle</a></li>
<li><a href="#run" class="contentUpdate" id="3"><i class="fas fa-running"></i>Run</a></li>
</ul>
</div>
<!-- /navbar -->
</div>
Кто-нибудь знает, что происходит? Я был бы очень признателен, если бы кто-нибудь мог мне помочь Моя панель навигации с активным классом