3

我有一个很大的 GIF 动画,我让它显示一个加载图标,直到加载 GIF。一旦加载,GIF 就会显示。效果很好,但我想添加一个“重播”按钮来触发 GIF 重播(重新加载)。

加载和 GIF 的代码:

HTML

<div id="loader" class="loading img-center"></div>

CSS

#loader {
 width: 600px;
 height: 450px;
 margin: auto; 
}

#loader.loading {
  background: url(/Images/ajax-loader.gif) no-repeat center center;
  width:32px;
  margin:auto ; 
}

JS

var $j = jQuery.noConflict();
$j(function () {
  var img = new Image();
  $j(img)
   .load(function () { 
     $j(this).hide();
     $j('#loader') 
      .removeClass('loading')
      .append(this);

  $j(this).fadeIn();
   })
 .error(function () {
   })
 .attr('src', '/2012/images/august/sailboat.gif');
});

上面的代码工作正常。现在对于不起作用的“重播”或“重新加载”代码:

HTML

<a id="refresh" href="#"> Replay Animation </a>

JS

$j(function() {
  $j("#refresh").click(function() {
     $j("#loader").load("/2012/images/august/sailboat.gif")
  })
})

我知道 JS 有一些错误,但由于我缺乏 JS 技能,我不知道我应该做什么或尝试什么。非常感谢任何帮助或建议!

谢谢!

4

2 回答 2

4

检查这个:

$j("#refresh").click(function() {
  $j("#loader").find('img').attr("src", "/2012/images/august/sailboat.gif");
});

与您之前的代码一样,您将图像附加在其中,#loader因此$('#loader').load(..)将不起作用。在其中找到图像#loader,然后更改该src图像的。

于 2012-08-07T05:19:19.970 回答
2

如果需要,您还可以附加时间戳以避免从缓存中加载图像:

$j("#refresh").click(function() {
  var timestamp = new Date().getTime();
  $j('#loader').find('img').attr('src', '/2012/images/august/sailboat.gif'+'?'+timestamp);
});
于 2012-08-07T05:21:24.490 回答