为了账号安全,请及时绑定邮箱和手机立即绑定

js如何根据图片是否已经缓存展现loading动画?

js如何根据图片是否已经缓存展现loading动画?

潇潇雨雨 2018-11-21 18:13:54
现有一个需求:点击列表进入详情页,详情页中有图片展示1.首次进入如果图片加载完毕了,关闭loading2.如果再次进入,浏览器缓存了这个图片,则不再显示loading3.如果这个列表不包含图片,点进去后不显示loading我用了个笨办法,一进去判断img的src是不是空,不是空就loading动画,然后使用jquery的.load()判断加载完毕后关闭$(function(){        if($("#img").attr("src").length==0){        layer.msg('Loading...', {               icon: 16,               shade: 0.01,              time: 3000          });    }        $("img").load(function(){        layer.closeAll('loading');    })});但这里有个问题,如果图片缓存了,进入仍然开启loading动画,但图片是直接显示的,求助可否能根据缓存来显示loading,或者我这个做法不对,有更好的方案?给个思路即可,有简单的伪代码更好,谢谢!
查看完整描述

1 回答

?
慕尼黑5688855

TA贡献1848条经验 获得超2个赞

var url = "http://......../image.jpg";

var img = new Image();

img.src = url;

 

if(img.complete) {

    alert('该图片已经存在于缓存之中,不会再去重新下载');

}else{

    alert('图片不存在缓存之中');

    img.onload = function() {

    alert('图片下载成功!');

}


查看完整回答
反对 回复 2018-12-31
  • 1 回答
  • 0 关注
  • 505 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信