Как анимировать Div в нижней части экрана

#javascript #html #css

Вопрос:

У меня есть разделитель, который открывается справа. В настоящее время он буквально начинается с верхней части страницы и «перемещается» вниз. Я хотел бы анимировать его справа внизу, а не сверху вниз.

Вот мой css:

 .helper {
width: 0px;
position: fixed;
bottom: 60px;
right: -10px;
background-color: #E3E7EA;
overflow-x: auto;
overflow-y: scroll;
transition: 0.5s;
padding-left: 10px;
z-index: 1000;
transition: all 0.4s ease 0s;
 

}

Вот мой javascript:

 function openHelper() {
var myBoxWidth = $("#myHelper").width();
if (myBoxWidth > 0) {
    document.getElementById("myHelper").style.width = "0px";
    document.getElementById("myHelper").style.right = '-10';
}
else {
    document.getElementById("myHelper").style.width = "520px";
    document.getElementById("myHelper").style.right = '0';
}
 

}
функция closeHelper() {
document.getElementById(«MyHelper»).style.ширина = «0 пикселей»;
document.getElementById(«MyHelper»).style.right = ‘-10’;
}

Вот мой HTML:

 <div id="myHelper" class="helper">
<span><a href="javascript:void(0)" class="closebtn" onclick="closeHelper()">X</a></span>
<div>
Lorem Ipsum is simply dummy text of the printing and typesetting industry. Lorem Ipsum has been the industry's standard dummy text ever since the 1500s, when an unknown printer took a galley of type and scrambled it to make a type specimen book. It has survived not only five centuries, but also the leap into electronic typesetting, remaining essentially unchanged. It was popularised in the 1960s with the release of Letraset sheets containing Lorem Ipsum passages, and more recently with desktop publishing software like Aldus PageMaker including versions of Lorem Ipsum.
</div>
 

Щелчок

Вот скрипка, демонстрирующая мою проблему, Моя скрипка

Ответ №1:

Просто измените высоту на фиксированную высоту в css:

 .helper {
    width: 0px;
    height: 300px;
    etc
}
 

Вот и все! Вот JSFiddle для того же самого: https://jsfiddle.net/dbrsgevf/3/

UPD: Альтернативой является использование максимальной высоты.

 .helper {
    width: 0px;
    max-height: 200px;
    etc
}
 

A JSFiddle для того же самого: https://jsfiddle.net/9o2g4e5x/

Другой альтернативой является ограничение размера с помощью максимальной высоты и использование javascript для редактирования этих ограничений. Это дает ему эффект роста:

JS:

 function openHelper() {
    var myBoxWidth = $("#myHelper").width();
    if (myBoxWidth > 0) {
        document.getElementById("myHelper").style.width = "0px";
        document.getElementById("myHelper").style.right = '-10';
        document.getElementById("myHelper").style.maxHeight = "0px";
    }
    else {
        document.getElementById("myHelper").style.width = "520px";
        document.getElementById("myHelper").style.right = '0';
        document.getElementById("myHelper").style.maxHeight = "190px";
    }
}
function closeHelper() {
    document.getElementById("myHelper").style.width = "0px";
    document.getElementById("myHelper").style.right = '-10';
    document.getElementById("myHelper").style.maxHeight = "0px";
}
 

CSS:

 .helper {
    width: 0px;
    max-height: 0px;
}
 

JSFiddle: https://jsfiddle.net/9o2g4e5x/2/

Комментарии:

1. Спасибо, но я не могу указать «определенную» высоту, потому что контент на самом деле динамичен. Ваш образец открывается и закрывается справа, но он не сворачивается и не расширяется снизу, как я хочу, чтобы он работал.

2. Вместо этого вы можете использовать максимальную высоту. Вы хотите, чтобы он рос снизу справа или просто выскакивал справа?

3. Большое спасибо!

4. нет проблем! Надеюсь, это помогло!