我已经构建了一个简单的动画功能,您可以单击一个展开框,如果可能,我宁愿不使用插件。
目前它看起来像这样:
$('#one').css("height", "22");
$('#t1').click(function() {
if ($('#one').hasClass("extended")) {
$('#one').stop(true, true).animate({height: '22px'},500);
$('#one').removeClass("extended");
$('#a1').stop(true, true).animate({opacity: '1'},500);
} else {
$('#one').animate({height: '120px'},500);
$('#one').addClass("extended");
$('#a1').animate({opacity: '0'},300);
}
});
但问题是,如果div内的文本溢出,那我怎么能把它设置为文本的高度?我希望这是有道理的!
HTML:
<div class="rightBox">
<div id="one" style="overflow:hidden;">
<h3><a href="#" id="t1">Availability</a></h3><p id="a1"><a href="#" title="Slide Down"><img src="<?php echo home_url(); ?>/img/arrow.png" alt="Arrow" /></a></p>
<?php include 'availability.php'; ?>
</div>
</div><!-- END.#rightBox -->
答案 0 :(得分:3)
我接近这个的方法是计算所有孩子的身高,然后开始到特定身高的动画。见下文。
请参阅此jsFiddle。
<div class="rightBox">
<div id="one" style="overflow:hidden;">
<h3><a href="#" id="t1">Availability</a></h3><p id="a1"><a href="#" title="Slide Down"><img src="/img/arrow.png" alt="Arrow" /></a></p>
<p>Sample text</p>
<p>Sample text</p>
<p>Sample text</p>
<p>Sample text</p>
<p>Sample text</p>
<span>More Sample text</span>
</div> </div>
的jQuery / JavaScript的
$('#one').css({"height": "22px", "background-color": "red"});
$('#t1').click(function() {
if ($('#one').hasClass("extended")) {
$('#one').stop(true, true).animate({height: '22px'},500);
$('#one').removeClass("extended");
$('#a1').stop(true, true).animate({opacity: '1'},500);
} else {
var height = 0;//initialize a height
$(this).closest("div").children().each(function(){//this loops through each child element
height += $(this).outerHeight(true);//this sums up the height
});
$('#one').animate({height: height + 'px'},500);//set the height
$('#one').addClass("extended");
$('#a1').animate({opacity: '0'},300);
} });
答案 1 :(得分:1)
如果您有权访问HTML,则可以将#one
的内容与另一个<div>
包装在一起,然后动态抓取其中的高度。
我还在该示例中展示了您可以对代码执行的一些链接,因此您不必连续调用$( '#one' )
,每次都会导致DOM查找。比这更好的是将它设置为一个你可以重用的变量:
var $one = $( '#one' );
答案 2 :(得分:0)
为什么不把文字放在包装中?要么是p还是div,要对它做一个.slideToggle()? 消除所有不必要的计算?
<div class="rightBox">
<div id="one" style="overflow:hidden;">
<h3><a href="#" id="t1">Availability</a></h3><p id="a1"><a href="#" title="Slide Down"> .. </a></p>
<p class="content" style="display:none">afasdfasdfasdfasdfasdf
as
df
asd <br />
f
asd
f
asd <br />
f
asd
f
asdf <br />
afasdfasdfasdfasdfasdf
as
df
asd <br />
f
asd
f
asd <br />
f
asd
f
asdf <br />
afasdfasdfasdfasdfasdf
as
df
asd <br />
f
asd
f
asd <br />
f
asd
f
asdf <br />
afasdfasdfasdfasdfasdf
as
df
asd <br />
f
asd
f
asd <br />
f
asd
f
asdf <br />
afasdfasdfasdfasdfasdf
as
df
asd <br />
f
asd
f
asd <br />
f
asd
f
asdf <br />
</p>
</div>
</div><!-- END.#rightBox -->
Javascript:
$('#t1').click(function() {
if ($('#one').hasClass("extended")) {
$('#one p.content').slideToggle();
//$('#one').stop(true, true).animate({height: '22px'},500);
$('#one').removeClass("extended");
$('#a1').stop(true, true).animate({opacity: '1'},500);
} else {
//$('#one').animate({height: 'auto'},500);
$('#one p.content').slideToggle();
$('#one').addClass("extended");
$('#a1').animate({opacity: '0'},300);
}
});