图片预加载,出现多次加载

发布于 2022-09-07 20:32:51 字数 836 浏览 22 评论 0

一个活动图片太多,想要做预加载,但是发现会出现多次加载,并没有从缓存中读取。

<body>
    <img src="./img/arrow.png" id="slogn">
    <div class="loading" id="loading" style="display: none;">
        <div class="slogan"></div>
    </div>
<script>
var loadImg = new Image();
loadImg.src = 'img/slogn.png';
loadImg.onload = function () {
    document.getElementById("slogn").src = 'img/slogn.png'
    setTimeout(function () {
        document.getElementById("loading").style.display = 'block'
    },5000)
}
</script>
</body>

css:


.slogan{
  background: url("../img/slogn.png") no-repeat center;
}

clipboard.png

我看有很多用new Image来预加载图片,但是这里来看并没有从缓存中读取数据,请问大家做活动通过什么方式来做到图片预加载。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

彩扇题诗 2022-09-14 20:32:51

你的图片文件的 header 没有设置可以缓存的,设置一下cache-control 和 etag

青衫儰鉨ミ守葔 2022-09-14 20:32:51

一般在活动页之前有个loading页面,将图片资源加载完后再跳转到活动页

可以才考下这个插件demo https://github.com/chenyinkai...

玩心态 2022-09-14 20:32:51

试试这个 npm i preload-all -S

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文