Я использую jquery.transit , чтобы переместить боковую панель в представление при нажатии кнопки, и я почти заставил ее работать, за исключением того, что она отображается под div 'leftpad' вместо того, чтобы показываться рядом с ним. Это, вероятно, потому, что мне пришлось использовать положение: относительное в css для перехода на работу. Если я использую фиксированное положение, боковая панель вообще не появляется, но элемент 'leftpad' перемещается, чтобы освободить место для него. Я не знаю, как это исправить.
Вот мой код:
$('#openNav').click(function() {
$("#leftpad").transition({'padding-left': "300px"},400);
$("#contentArea").transition({'width':'95%','display':'inline-block'},400);
$("#sidebar").transition({ x: '300px', y:'0px' });
$("#openNav").hide();
});
$('#closeNav').click(function() {
$("#leftpad").transition({'padding-left': "0px"},400)
$("#contentArea").transition({'width':'70%','display':'block'},400);
$("#sidebar").transition({ x: '-300px', y: '0px' });
$("#openNav").show();
});
Вот CSS:
#leftpad{
padding: 0;
margin: 0;
}
#sidebar {
height: 100%;
width: 300px;
position: relative;
z-index: 1;
top: 0;
left: -300px;
overflow: hidden;
text-align: center;
}
Вот HTML:
<div id="leftpad">
<header role="banner" class="banner_image boxshadowM enclosure1" >
<div class="gradient2">
<button id="openNav" class="button1 boxshadowM">☰</button>
<h1><strong id="sitetitle">Blockpress</strong></h1>
<h2 id="tagline"></h2>
</div>
</header>
<div id="contentArea" class="boxshadowM enclosure2"></div>
</div>
<div id="sidebar" class="enclosure3">
<button id="closeNav" class="button2">×</button>
<nav>...</nav>
<footer>...</footer>
</div>