我想要
- 淡出图像
- 预加载替换图像
- 更改图像源以显示新图像
- 淡入(新)图像
出于某种原因,虽然当图像淡入时,有一个非常短暂的时刻,旧图像被看到然后被新图像取代。我不认为这是图像操作之间的时间冲突......还有什么会导致这种闪烁?
// old image: about.jpg
// new image: contact.jpg
$('#content').fadeTo(1500, 0.01, function(){
var container = $(this);
// gather image information
var src = img.parent().attr('href');
imgData = { 'alt': img.attr('alt'), 'src': src, 'cap': '' };
// change background image & caption (after image has been cached)
var imgSrc = sanitizeBackgroundImage( imgData );
$.get( imgSrc, function(data) {
// set background image src to preloaded image
$("#content>img").attr({"src": imgData.src});
$("#content>img").attr({"alt": imgData.alt});
// update caption text
$('#bottom-caption').html('<span>' + imgData.cap + '</span>');
// fade image container back in
console.log( 'before fadeIn: ' + $("#content>img").attr("src") );
container.fadeTo(750, 1);
});
});
控制台正确读取
before fadeIn: /images/large/contact.jpg