0

0

如何避免多页网站中重复执行加载动画

心靈之曲

心靈之曲

发布时间:2026-01-30 12:43:02

|

226人浏览过

|

来源于php中文网

原创

如何避免多页网站中重复执行加载动画

本文介绍如何通过 localstorage 实现跨页面的加载状态持久化,使加载动画仅在用户首次访问网站时触发一次,后续跳转至其他 html 页面(如 about.html)时自动跳过,提升用户体验。

在多页静态网站(如 index.html 和 about.html)中,若每个页面都嵌入相同的加载屏(#load)和计数逻辑,用户每次跳转都会重新触发 0% → 100% 动画——这不仅违背“一次性加载”的设计初衷,也造成不必要的性能开销与体验割裂。

根本原因在于:HTML 页面是独立加载的,JavaScript 执行环境不共享,且默认无状态记忆能力。因此,必须引入客户端持久化机制来标记“加载已完成”。

✅ 推荐方案:使用 localStorage 记录加载完成状态

在 counter() 函数执行前,先检查本地存储中是否存在标记(例如 'loadCompleted': 'true')。若存在,则直接跳过整个加载流程,并立即应用动画类;否则执行计数逻辑,并在达到 100% 后写入该标记。

玄鲸Timeline
玄鲸Timeline

一个AI驱动的历史时间线生成平台

下载

以下是优化后的完整实现:


0
function counter() {
    const loadNo = document.getElementById('load-no');
    const load = document.getElementById('load');

    // ✅ 检查是否已加载完成
    if (localStorage.getItem('loadCompleted') === 'true') {
        // 直接移除加载屏并应用动画类(模拟已完成状态)
        load.classList.add('loaded');
        document.body.classList.add('loaded-body'); // 可选:用于全局样式控制

        // 立即为关键元素添加动画类(与原逻辑一致)
        const evLogo = document.getElementById('ev-logo');
        const navLinks = document.querySelectorAll('.nav-a');
        const fbIcon = document.querySelector('.fb-icon');
        const githubIcon = document.querySelector('.github-icon');
        const lineH = document.querySelector('.line-h');
        const lineV = document.querySelector('.line-v');
        const copyrightIcon = document.querySelector('.copyright-icon');
        const yearEl = document.querySelector('.year');
        const nameEl = document.querySelector('.name');
        const earlEl = document.querySelector('.earl-villarias');
        const sloganText = document.querySelector('.slogan-text');
        const sloganLines = document.querySelectorAll('.slogan-line');

        if (evLogo) evLogo.style.transform = 'translate3d(0px, 0px, 0px)';
        if (fbIcon) fbIcon.classList.add('fb-icon-s');
        if (githubIcon) githubIcon.classList.add('github-icon-s');
        if (lineH) lineH.classList.add('line-expand-h');
        if (lineV) lineV.classList.add('line-expand-v');
        if (copyrightIcon) copyrightIcon.classList.add('icon-year-s');
        if (yearEl) yearEl.classList.add('icon-year-s');
        if (nameEl) nameEl.classList.add('name-s');
        if (earlEl) earlEl.classList.add('name-show');
        if (sloganText) sloganText.classList.add('slogan-show');
        sloganLines.forEach(el => el.classList.add('slogan-line-expand'));
        navLinks.forEach(link => link.classList.add('s-d'));

        // 隐藏加载屏(可配合 CSS transition)
        load.style.opacity = '0';
        setTimeout(() => {
            load.style.display = 'none';
        }, 300);

        return; // ✅ 提前退出,不再执行计数
    }

    // ❌ 否则执行原始计数逻辑
    const counts = setInterval(() => {
        const number = parseInt(loadNo.textContent) || 0;
        loadNo.textContent = (number + 1).toString();

        if (loadNo.textContent === '100') {
            clearInterval(counts);
            localStorage.setItem('loadCompleted', 'true'); // ✅ 永久标记完成

            // 执行与上方完全相同的动画类添加逻辑(复用更佳,此处为清晰展示)
            if (evLogo) evLogo.style.transform = 'translate3d(0px, 0px, 0px)';
            if (fbIcon) fbIcon.classList.add('fb-icon-s');
            if (githubIcon) githubIcon.classList.add('github-icon-s');
            if (lineH) lineH.classList.add('line-expand-h');
            if (lineV) lineV.classList.add('line-expand-v');
            if (copyrightIcon) copyrightIcon.classList.add('icon-year-s');
            if (yearEl) yearEl.classList.add('icon-year-s');
            if (nameEl) nameEl.classList.add('name-s');
            if (earlEl) earlEl.classList.add('name-show');
            if (sloganText) sloganText.classList.add('slogan-show');
            sloganLines.forEach(el => el.classList.add('slogan-line-expand'));
            navLinks.forEach(link => link.classList.add('s-d'));

            // 平滑隐藏加载屏
            load.style.transition = 'opacity 0.3s ease-out';
            load.style.opacity = '0';
            setTimeout(() => {
                load.style.display = 'none';
            }, 300);
        }
    }, 30); // 每30ms递增1%,全程约3秒
}

// 页面加载完成后启动
document.addEventListener('DOMContentLoaded', counter);

? 关键注意事项

  • localStorage 是同源(origin)隔离的,确保 index.html 和 about.html 在同一协议、域名、端口下运行(如 http://localhost:5500/),否则无法共享状态;
  • 若需支持「强制刷新重载」或「清除加载状态」,可增加调试按钮:localStorage.removeItem('loadCompleted');
  • 建议为 #load 添加 CSS 过渡效果(如 transition: opacity 0.3s),使隐藏更自然;
  • 生产环境中,可将重复的 DOM 操作逻辑封装为函数(如 applyAnimations()),提升可维护性。

通过这一方案,用户首次访问任一页面(如 index.html)时触发完整加载动画;随后点击导航跳转至 about.html,页面将瞬间呈现最终状态——真正实现「单次加载、全站生效」的流畅体验。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

3368

2024.08.14

css3transition
css3transition

css3transition属性用于指定如何从一个CSS样式过渡到另一个CSS样式,本专题为大家提供transition相关的文章、相关下载和相关课程,大家可以免费体验。

231

2023.06.27

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

418

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

2370

2024.03.12

http与https有哪些区别
http与https有哪些区别

http与https的区别:1、协议安全性;2、连接方式;3、证书管理;4、连接状态;5、端口号;6、资源消耗;7、兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

2115

2024.08.16

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

8

2026.01.30

c++ 字符串格式化
c++ 字符串格式化

本专题整合了c++字符串格式化用法、输出技巧、实践等等内容,阅读专题下面的文章了解更多详细内容。

9

2026.01.30

java 字符串格式化
java 字符串格式化

本专题整合了java如何进行字符串格式化相关教程、使用解析、方法详解等等内容。阅读专题下面的文章了解更多详细教程。

8

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 25.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号