前端发版上线出现白屏问题

2024-03-27 15:20

本文主要是介绍前端发版上线出现白屏问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

    • 路由配置问题
    • 资源缓存问题
    • 首屏加载过慢

:喂,你的页面白啦!

出现上线白屏的问题有很多,如:配置错误、缓存问题、浏览器兼容问题,根据不同情况去解决。

路由配置问题

问题描述: 在vue开发的前端网页上线后,出现白屏,刷新页面报404错误。

问题分析: 项目上线之后出现白屏,且刷新之后也找不到资源,服务器静态资源文件加载失败,出现这种情况,通常是路由配置的问题。

解决方案:

配置路由:在vue-router的配置中设置mode为history模式(history模式:当用户在地址栏中输入或刷新页面时,浏览器会向服务器发送关于路径的请求),在服务器端配置URL重写规则,即:在Nginx中使用try_files指令,将所有路径都重定向到入口文件(比如index.html),这样即使用户在地址栏中输入或刷新页面,服务器也会正确返回入口文件,而不会出现404错误。

// vue-router配置
const router = new VueRouter({mode: 'history',routes: [...]
});
// nginx配置
location / {root ...index ...try_files $uri $uri/ /index.html;
}
location @router {rewrite ^.*$ /index.html last;
}

资源缓存问题

问题描述: web页面白屏,需要清除缓存数据重新加载才能正常访问。单页面的项目,客户不想每次发版都刷新,也不希望每次都重新加载资源文件(即使是缓存也需要刷新和加载)。

问题分析:

在首次上线项目的时候,build生成的资源文件直接放到服务端上线即可。但之后上线,在客户端会默认缓存index.html入口文件,但vue打包生成的css/js都是hash值,跟上次的文件名都不一样,因此会出现找不到css/js的情况,导致出现白屏的问题。

解决问题: 发版后前端页面白屏,通过刷新才能访问前端页面。我个人觉得这个问题无法解决,因为不管怎么做,服务器资源发生变化了,在web页面更新资源的时候都需要一定的缓冲时间。

优化方案:

1、配置资源缓存

确保index.html不被缓存,这样每次用户访问时都会从服务器获取最新版本。在index.html文件的meta标签中添加缓存控制信息,在服务端的响应头中设置合适的缓存过期时间。对index.html入口文件不缓存,css/js资源设置缓存过期时间。

<meta http-equiv="Cache-Control" content="no-cache, no-store, must-revalidate" />
<meta http-equiv="Pragma" content="no-cache" />
<meta http-equiv="Expires" content="0" />
<meta http-equiv="Cache" content="no-cache">
// nginx配置
#为了解决线上发布新版本后访问前端页面出现短暂性白屏问题,就是把缓存给禁用掉
location = /index.html {add_header Cache-Control "no-store, no-cache, no-transform, must-revalidate, max-age=0";add_header Pragma "no-cache";  add_header Expires "0";
}location / {#需要指向下面的@router否则会出现vue的路由在nginx中刷新出现404try_files $uri $uri/ @router;index  index.html index.htm;
}
#对应上面的@router,主要原因是路由的路径资源并不是一个真实的路径,所以无法找到具体的文件
#因此需要rewrite到index.html中,然后交给路由在处理请求资源
location @router {rewrite ^.*$ /index.html last;
}

2、增加版本号或时间戳到资源文件名

通过在构建过程中将版本号或时间戳添加到资源文件名中,可以避免浏览器加载旧的缓存资源。

// vue.config.js
module.exports = {  outputDir: 'dist',  filenameHashing: true, // 确保文件名包含hash  chainWebpack: config => {  config.output  .filename(`js/[name].[contenthash].js`)  .chunkFilename(`js/[name].[contenthash].chunk.js`);  }  
}

首屏加载过慢

问题描述: 用户打开页面,出现长时间的白屏,特别是对于单页面应用来说。

问题分析:

出现首页长时间白屏的原因有很多:

1、首页需要加载大量的资源或依赖
2、服务器请求速度太慢
3、首页的样式太复杂,需要渲染很长时间
4、浏览器兼容问题

优化方案:

1、代码拆分+按需(懒)加载:将页面依赖的资源进行代码拆分,通过按需加载或懒加载的方式,延迟加载非必要的资源,只有当用户需要访问到某个模块的时候再去加载对应的资源。

2、预加载资源:通过标签来预加载关键资源,提前加载必要资源。

3、CSS优化:可以通过css预编译器来提高css代码的复用性,避免使用过多的CSS样式和复杂的选择器,尽量减少页面重绘和重排的次数,优化CSS文件加载和解析速度。

4、异步加载脚本:将JavaScript脚本放在页面底部或使用defer、async属性进行异步加载,避免脚本阻塞页面渲染。

5、服务器性能优化: 对服务器进行性能优化,如:CDN加速、启用Gzip压缩、配置合适的缓存策略等,提高资源加载速度。

6、服务端渲染:对于单页面应用,考虑使用服务端渲染(SSR)技术,在服务器端生成页面的HTML内容,减少客户端渲染时间,加快首屏加载速度。

7、缓存优化:利用浏览器缓存机制和服务端缓存技术,减少重复请求,加快页面加载速度。

在这里插入图片描述

参考文章:

彻底解决前端发版白屏问题和解决方案

【优化】vue项目缓存引发的白屏

灰度发布、蓝绿部署、金丝雀都是啥?

Vue 项目中首页长时间白屏的原因及解决方法

这篇关于前端发版上线出现白屏问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

vite搭建vue3项目的搭建步骤

《vite搭建vue3项目的搭建步骤》本文主要介绍了vite搭建vue3项目的搭建步骤,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录1.确保Nodejs环境2.使用vite-cli工具3.进入项目安装依赖1.确保Nodejs环境

Nginx搭建前端本地预览环境的完整步骤教学

《Nginx搭建前端本地预览环境的完整步骤教学》这篇文章主要为大家详细介绍了Nginx搭建前端本地预览环境的完整步骤教学,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录项目目录结构核心配置文件:nginx.conf脚本化操作:nginx.shnpm 脚本集成总结:对前端的意义很多

IDEA和GIT关于文件中LF和CRLF问题及解决

《IDEA和GIT关于文件中LF和CRLF问题及解决》文章总结:因IDEA默认使用CRLF换行符导致Shell脚本在Linux运行报错,需在编辑器和Git中统一为LF,通过调整Git的core.aut... 目录问题描述问题思考解决过程总结问题描述项目软件安装shell脚本上git仓库管理,但拉取后,上l

前端缓存策略的自解方案全解析

《前端缓存策略的自解方案全解析》缓存从来都是前端的一个痛点,很多前端搞不清楚缓存到底是何物,:本文主要介绍前端缓存的自解方案,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、为什么“清缓存”成了技术圈的梗二、先给缓存“把个脉”:浏览器到底缓存了谁?三、设计思路:把“发版”做成“自愈”四、代码

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

Vue3视频播放组件 vue3-video-play使用方式

《Vue3视频播放组件vue3-video-play使用方式》vue3-video-play是Vue3的视频播放组件,基于原生video标签开发,支持MP4和HLS流,提供全局/局部引入方式,可监听... 目录一、安装二、全局引入三、局部引入四、基本使用五、事件监听六、播放 HLS 流七、更多功能总结在 v

idea npm install很慢问题及解决(nodejs)

《ideanpminstall很慢问题及解决(nodejs)》npm安装速度慢可通过配置国内镜像源(如淘宝)、清理缓存及切换工具解决,建议设置全局镜像(npmconfigsetregistryht... 目录idea npm install很慢(nodejs)配置国内镜像源清理缓存总结idea npm in

pycharm跑python项目易出错的问题总结

《pycharm跑python项目易出错的问题总结》:本文主要介绍pycharm跑python项目易出错问题的相关资料,当你在PyCharm中运行Python程序时遇到报错,可以按照以下步骤进行排... 1. 一定不要在pycharm终端里面创建环境安装别人的项目子模块等,有可能出现的问题就是你不报错都安装

idea突然报错Malformed \uxxxx encoding问题及解决

《idea突然报错Malformeduxxxxencoding问题及解决》Maven项目在切换Git分支时报错,提示project元素为描述符根元素,解决方法:删除Maven仓库中的resolv... 目www.chinasem.cn录问题解决方式总结问题idea 上的 maven China编程项目突然报错,是

Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题

《Python爬虫HTTPS使用requests,httpx,aiohttp实战中的证书异步等问题》在爬虫工程里,“HTTPS”是绕不开的话题,HTTPS为传输加密提供保护,同时也给爬虫带来证书校验、... 目录一、核心问题与优先级检查(先问三件事)二、基础示例:requests 与证书处理三、高并发选型: