当我按“联系人”时,我希望创建一个幻灯片DIV,就像here一样。有人知道类似的东西吗?
答案 0 :(得分:13)
使用jQuery's slideToggle()
方法可以帮助您完成此操作。
HTML:
<div id="contact">
Contact me!
</div>
<a href="#" id="toggle">Contact</a>
CSS:
#contact
{
display: none;
background: grey;
color: #FFF;
padding: 10px;
}
JavaScript的:
$(function()
{
$("a#toggle").click(function()
{
$("#contact").slideToggle();
return false;
});
});
答案 1 :(得分:13)
如果你不想使用jQuery,你可以尝试使用现代浏览器:
演示:http://jsfiddle.net/ThinkingStiff/EVyE8/
HTML:
<div id="slide">click me</div>
CSS:
#slide {
height: 50px;
transition: height 500ms ease;
-moz-transition: height 500ms ease;
-ms-transition: height 500ms ease;
-o-transition: height 500ms ease;
-webkit-transition: height 500ms ease;
}
脚本:
document.getElementById( 'slide' ).addEventListener( 'click', function() {
this.style.height == '50px' || this.style.height == ''
? this.style.height = '150px'
: this.style.height = '50px';
}, false );
答案 2 :(得分:5)
又一个示例,但没有jquery,并且有一个类添加/删除方法:)
演示:http://jsfiddle.net/1wbh8pqj/
主要思想是你有两个类,其中一个适用于滑块,另一个表示滑块在展开时应该如何显示。
.slider {
height: 0px;
overflow: hidden;
transition: height 0.5s ease;
-moz-transition: height 0.5s ease;
-ms-transition: height 0.5s ease;
-o-transition: height 0.5s ease;
-webkit-transition: height 0.5s ease;
}
.slided {
height: 100px;
}
所以,你必须在必须展开时将'slided'类设置为滑块,并在滑块必须缩小时将其移除,并使用超级超级超级强大的css过渡,高度会顺利改变:)
var expander = document.getElementById("expander");
expander.addEventListener("click", function () {
var slider = document.getElementsByClassName("slider")[0];
if (slider.classList.contains("slided")) {
slider.classList.remove("slided");
} else {
slider.classList.add("slided");
}
});
ohbtw,html:
<div class="slider">i am teh slidah!! :D</div>
<div class="content">and i am the content XD</div>
<div id="expander">click me to expand/hide the slidah! :O</div>
答案 3 :(得分:2)
<div id="slide">
Slide content<br />
Slide content<br />
Slide content<br />
</div>
<div id="content">
Content<br />
Content<br />
Content<br />
</div>
<button id="slide_button">Slide it</button>
#content {
background-color: #c0c0c0;
border: 1px solid blue;
}
#slide {
border: 1px solid red;
background-color: #000;
color: #fff;
overflow: hidden;
}
$('#slide_button').click(function() {
$('#slide').animate({
height: 'toggle'
}, 1500, function() {
});
});
答案 4 :(得分:1)
使用jQuery,你可以创建div并使用css添加display:none。然后,像:
$('.button').click(function(e){
e.preventDefault();
$('#mydiv').slideToggle();
});
答案 5 :(得分:0)
The almighty jQuery comes to a rescue, once again
如果您不想使用jquery,只需设置一个计时器并增加高度。