jQuery 图像加载插件
大家好
我正在尝试创建一个带有缩略图的简单幻灯片库。
我正在使用循环插件来创建幻灯片和缩略图
http://www.ttmt.org.uk/gallerytest/
缩略图位于窗口底部的粘性页脚中。
我希望幻灯片图像填充窗口的其余部分并在调整窗口大小时进行缩放。
我正在用这个功能做这个
function resizeImg() {
$('#slideshow img').css({'height':$('#wrap').height()-footerHeight,'width':'auto'});
}
目前,这在调整窗口大小时有效,但在首次加载图像时无效。
我需要在加载图像时调用该函数。
我发现 imagesloaded 插件看起来可以工作 - https://github.com/desandro/imagesloaded
我的问题是我看不到如何在我的代码中使用该插件。
谁能解释我如何使用 imagesloaded 插件来调用我的 resizeImg 函数。
<!DOCTYPE html>
<html>
<head>
<title>Title of the document</title>
<!--jQuery-->
<script type="text/javascript" src="js/jquery1.7.2.js"></script>
<script type="text/javascript" src="js/cycle.js"></script>
<!--CSS-->
<style type="text/css">
*{
margin:0;
padding:0;
}
ul{
list-style:none;
}
/**/
html, body {
height:100%;
text-align:center;
}
#wrap {
margin:auto;
min-height:100%;
margin-top:-100px;
text-align:left;
}
* html #wrap {
height:100%
}
#header {
background:red;
border-top:100px solid #fff;
}
#footer {
background:#eee;
margin:auto;
height:100px;
clear:both;
}
/**/
#slideshow img{
margin:0 0 0 55px;
height:100%;
}
div#thumbWrap {
position: relative;
height: 100px;
width: 500px;
overflow: auto;
margin:0 0 0 50px;
}
ul#thumbs {
display: block;
width: 2000px;
padding: 15px 0 0 15px;
}
ul#thumbs li {
display: block;
float: left;
padding: 0 4px;
}
ul#thumbs a {
display: block;
text-decoration: none;
}
ul#thumbs img {
border: 3px #fff solid;
}
ul#thumbs a:hover img {
opacity: 0.5;
}
#slideshow img { display: none }
#slideshow img.first { display: block }
</style>
</head>
<body>
<div id="wrap">
<div id="header">
</div><!-- #header -->
<div id="slideshow">
<img src="images/plane01.jpg" alt="" class="first"/>
<img src="images/plane02.jpg" alt="" />
<img src="images/plane03.jpg" alt="" />
<img src="images/plane04.jpg" alt="" />
<img src="images/plane05.jpg" alt="" />
<img src="images/plane06.jpg" alt="" />
<img src="images/plane07.jpg" alt="" />
<img src="images/plane08.jpg" alt="" />
<img src="images/plane09.jpg" alt="" />
<img src="images/plane10.jpg" alt="" />
</div><!-- #content -->
</div><!-- #wrap -->
<div id="footer">
<div id="thumbWrap">
<ul id="thumbs">
</ul>
</div>
</div>
<script type="text/javascript">
$(window).load(function() {
resizeImg();
/*-cycle
*/
$('#slideshow').cycle({
fx: 'fade',
speed: 'fast',
timeout: 0,
pager: '#thumbs',
before: resizeImg(),
pagerAnchorBuilder: function(idx, slide) {
return '<li><a href="#"><img src="' + slide.src + '" width="auto" height="50" /></a></li>';
}
});
/*-thumbnailScroll
*/
var div = $('div#thumbWrap'), ul = $('ul#thumbs'), ulPadding = 15;
var divWidth = div.width();
div.css('overflow','hidden');
var lastLi = ul.find('li:last-child');
div.mousemove(function(e){
var ulWidth = lastLi[0].offsetLeft + lastLi.outerWidth() + ulPadding;
var left = (e.pageX - div.offset().left) * (ulWidth-divWidth) / divWidth;
div.scrollLeft(left);
});
var footerHeight = $('#footer').height();
function resizeImg() {
$('#slideshow img').css({'height':$('#wrap').height()-footerHeight,'width':'auto'});
}
$(window)
.scroll(resizeImg)
.resize(resizeImg)
.onload(resizeImg)
});
</script>
</body>
</html>
- - - - 更新 - - - - -
我现在几乎可以正常工作了。
http://www.ttmt.org.uk/gallerytest/
imagesLoaded 插件在加载时调整第一张图像的大小,然后我使用
after: resizeImg
在循环函数中调用图像加载后的调整大小函数。
我留下的问题是在图像加载后调用 resizeImg 函数时图像大小的跳跃。
任何人都可以找到解决这种尺寸跳跃的方法吗