一旦用户单击菜单切换按钮,我希望对侧边栏进行动画处理。
控制台中没有错误,当我在菜单中单击执行功能的1
函数时,单击菜单按钮时肯定会触发。尽管如此,侧栏永远不会出现在屏幕上。
代码如下:
侧边栏
alert()
JavaScript
<div class="sidebarContainer"
style="width: 15em; height: 100%; position: fixed; left: -300px; background-color: #333; z-index: 999; overflow: scroll;">
<div class="titleContainer"
style="text-align: center; padding-top: 2rem; padding-bottom: 1rem; background-color: #222;">
<img style="width: 6rem; height: 6rem; border-radius: 50px;"
src="/images/users/icons/{{ Auth::user()->icon_path }}">
<br><br>
<span style="color: white;">{{ Auth::user()->name }}</span>
</div>
@foreach($Menus as $menu)
<div id="linkContainer" class="linkContainer" style="padding: 0.3rem;">
<a style="text-decoration: none; color: white; padding-left: 0.3rem;" href="/{{ $menu->slug }}">{!!
$menu->icon_path !!} {{ $menu->name }}</a>
</div>
@endforeach
<div id="linkContainer" class="linkContainer" style="padding: 0.3rem;">
<a style="text-decoration: none; color: white; padding-left: 0.3rem;" href="{{ route('logout') }}"
onclick="event.preventDefault(); document.getElementById('logout-form').submit();"><i
class="fas fa-sign-out-alt"></i> Logout</a>
<form id="logout-form" action="{{ route('logout') }}" method="POST" style="display: none;">
@CSRF
</form>
</div>
<br><br>
</div>
任何帮助,谢谢:)
答案 0 :(得分:1)
您指的是sidebarContainer ID,但div仅具有sidebarContainer类。我更新了代码,将点击也添加到了函数调用中。
<script type="text/javascript">
$(function(){
$("#linkContainer:nth-child(odd)").css('background-color', '#222');
$("#menuToggle").click(function(){
$(".sidebarContainer").animate({"left": "0px"});
});
});
</script>
换句话说,您很可能在此循环中复制IDS,并且ID具有唯一性:
@foreach($Menus as $menu)
<div id="linkContainer" class="linkContainer" style="padding: 0.3rem;">
答案 1 :(得分:0)
确保sideContainerbar位于CSS中,并且可能在CSS中也具有left属性的值。 left属性仅适用于定位的元素。 (相对或绝对),也可以包含相对于要提供的对象的位置作为动画函数的参数。 #欢呼声