0

我有这个代码:

$('.pic_windows img').mouseenter(function () {
    $(this).effect('shake', {
        times : 4,
        distance : 5
    }, 15).attr('src', $(this).attr('src').replace(/.jpg/, '-1.jpg'))
});

$('.pic_windows img').mouseleave(function () {
    $(this).attr('src', $(this).attr('src').replace(/-1.jpg/, '.jpg'))
});

我正在使用 JQuery 的 .attr 交换图像,但我希望交换发生在大约 1 秒的过程中。我已经用谷歌搜索了所有这些复杂的“使用 JQuery 回退的 CSS3 转换”教程。有没有办法“动画”一个 .attr 变化?

我想我应该做一个淡入淡出,而另一个淡入淡出,但我不知道怎么写,因为我几乎是一个完整的 JQuery 新手。在几页的过程中,我有许多这样的过渡要做。如果我只需要为一个实例写这个,那将是小菜一碟。

更新 在 mouseenter 上,图像会抖动,然后应该在此抖动期间从一张图片淡入到其交换的图片。在 mouseleave 上,图像应该只是淡化回原始图片。不幸的是,我还发现抖动效果在 IE、所有版本以及图像交换上都出现了问题(根本看不到图像 2)

4

1 回答 1

2

不,您不能为属性更改设置动画。您可以做的是克隆一个元素,更改一个属性并在它们之间进行转换。

var target = $(this).fadeOut();
var src = target.attr('src').replace(/-1.jpg/, '.jpg');
var copy = target.clone()
    .attr('src', src)
    .hide()
    .insertAfter(target)
    .fadeIn();

编辑:感谢您澄清您的意图,我建议不要使用“src”,这基本上需要构建一个小型有状态插件。相反,在这里坚持所需的效果,在悬停时显示图像。jsFiddle

HTML

<div class="shaker">
    <img src="http://lorempixel.com/output/nature-q-c-360-240-3.jpg" />
    <img class="hover" src="http://lorempixel.com/output/technics-q-c-360-240-9.jpg" />
</div>​

CSS

.shaker {
    position: relative;
}
.shaker img {
    position: absolute;
}
.hover {
    display: none;
}

JS

$('.shaker').hover(function () {
    $(this).effect('shake', {
        times: 4,
        distance: 5
    }, 15);
    $(this).find('.hover').fadeIn();
}, function () {
    $(this).find('.hover').stop().fadeOut();
});​

http://jsfiddle.net/eHQ3t/13/

于 2012-05-29T03:21:56.163 回答