项目性能优化实战:解决首页白屏问题,自定义 loading 动画优化首屏效果

本文主要是介绍项目性能优化实战:解决首页白屏问题,自定义 loading 动画优化首屏效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求

初次打开项目的某个页面时,因为网络等原因,可能会导致包体积过大。

解决方案

准备工作(使用 gka 把 gif 转化成 svg)

需要借助 gka 这个工具。这个工具是一键快速图片优化、生成动画文件的。只需要全局安装,配合一些命令,即可将图片转成 canvas/css/svg 动画。
首先,让 UI 把 .gif 动图转换成一系列的图片,每张图片都表示此动画的单帧。然后通过命令gka <文件夹路径> -m true -t svg --minirate 0-20 -s,将动画的单帧合并成一张雪碧图,按一定的压缩比率进行压缩,最后生成 svg 格式的动画文件。
由于文章内容需要脱敏,下面放一个 gka 文档里的图。左边的表示 loading gif 的所有单帧,用 gka 工具后,能压缩成一张雪碧图合配套的 .css 文件,.html 文件为演示这个动画要如何使用。

生成的文件:
生成的文件

单帧 → svg / canvas 动效:
在这里插入图片描述

在项目中使用 svg 动画

首先,需要将 gka 生成的雪碧图和 css 文件,都放在项目的public文件夹下。这次我将雪碧图放在了public\img\loading-sprites.png,css 文件放在了public\static\css\loading.css下。并对 css 文件里的命名做了优化。

.loading-animation {width: 640px;height: 307px;background-image: url("/img/loading-sprites.png");background-repeat: no-repeat;animation-name: keyframes-loading;animation-duration: 2.88s;animation-delay: 0s;animation-iteration-count: infinite;animation-fill-mode: forwards;animation-timing-function: steps(1);
}@keyframes keyframes-loading {0% {width: 640px;height: 307px;background-image: url("/img/loading-sprites.png");}1.39% {background-position: -640px 0px;}2.78% {background-position: -1280px 0px;}4.17% {background-position: -1920px 0px;}5.56% {background-position: -2560px 0px;}/* 此处省略了一些代码 */97.22% {background-position: -44800px 0px;}98.61%,100% {background-position: -45440px 0px;}
}

然后,在入口页 index.html 引入上面提到的 css 文件。
之后,参考 gka 生成的 .html 文件,在页面 body 下添加 svg 元素。让页面一打开,就展示出 loading 的效果,取代原来的白屏。可以通过 svg 标签的 style 属性,指定 width 的值,改变 svg 的大小。

<!DOCTYPE html>
<html lang="zh"><head><!-- 此处省略了其他代码 --><link rel="stylesheet" href="/static/css/loading.css"></head><body><div id="first-loading-wrap" style="display: flex; justify-content: center; align-items: center; height:96vh; z-index: 999;"><svg id="first-loading-svg" viewBox="0, 0, 640, 307" style="width: 320px"><foreignObject id="first-loading-foreignobject" width="640" height="307"><div id="first-loading-content" class="loading-animation"></div></foreignObject></svg></div><div id="app"></div><!-- built files will be auto injected --></body></html>

最后,在路由的afterEach钩子函数里,移除 loading 效果相关的元素即可。

router.afterEach(to => {// 判断是否需要去除 loading 效果document.getElementById('first-loading-wrap')?.remove()document.getElementById('first-loading-svg')?.remove()document.getElementById('first-loading-foreignobject')?.remove()document.getElementById('first-loading-content')?.remove()// 省略其他逻辑
})

这篇关于项目性能优化实战:解决首页白屏问题,自定义 loading 动画优化首屏效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/318205

相关文章

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

C++右移运算符的一个小坑及解决

《C++右移运算符的一个小坑及解决》文章指出右移运算符处理负数时左侧补1导致死循环,与除法行为不同,强调需注意补码机制以正确统计二进制1的个数... 目录我遇到了这么一个www.chinasem.cn函数由此可以看到也很好理解总结我遇到了这么一个函数template<typename T>unsigned

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

Three.js构建一个 3D 商品展示空间完整实战项目

《Three.js构建一个3D商品展示空间完整实战项目》Three.js是一个强大的JavaScript库,专用于在Web浏览器中创建3D图形,:本文主要介绍Three.js构建一个3D商品展... 目录引言项目核心技术1. 项目架构与资源组织2. 多模型切换、交互热点绑定3. 移动端适配与帧率优化4. 可

sky-take-out项目中Redis的使用示例详解

《sky-take-out项目中Redis的使用示例详解》SpringCache是Spring的缓存抽象层,通过注解简化缓存管理,支持Redis等提供者,适用于方法结果缓存、更新和删除操作,但无法实现... 目录Spring Cache主要特性核心注解1.@Cacheable2.@CachePut3.@Ca