Это хороший вариант использования postion:fixed;
. Приведенный ниже пример поможет вам начать. Вы можете легко создавать разные классы, когда боковая панель скрыта, и просто переключать классы в div, чтобы использовать разные значения позиции.
HTML
<div class="sidebar">side stuff</div>
<div class="main">main content</div>
CSS
.sidebar{
background-color:#CCC;
position:fixed;
left:0;
top:0;
bottom:0;
width:150px;
}
.main{
background-color:#AAA;
position:fixed;
left:150px;
top:0;
bottom:0;
right:0;
}