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

目录

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

:喂,你的页面白啦!

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

路由配置问题

问题描述: 在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://xiahunao.cn/news/2906618.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

C语言中的联合体和枚举

联合体 联合体的创建 联合体的关键字是union union S {char a;int i; };除了关键字和结构体不一样之外&#xff0c;联合体的创建语法形式和结构体的很相似&#xff0c;如果不熟悉结构体的创建&#xff0c;可以看一下我上一篇的博客关于结构体知识的详解。 联合体的特点 联合…

HarmonyOS 应用开发之进程模型

系统的进程模型如下图所示。 应用中&#xff08;同一Bundle名称&#xff09;的所有UIAbility、ServiceExtensionAbility和DataShareExtensionAbility均是运行在同一个独立进程&#xff08;主进程&#xff09;中&#xff0c;如下图中绿色部分的“Main Process”。应用中&#x…

matlab及其在数字信号处理中的应用001:软件下载及安装

目录 一&#xff0c;matlab的概述 matlab是什么 matlab适用于的问题 matlab的易扩展性 二&#xff0c;matlab的安装 1&#xff0c;解压所有压缩文件 2&#xff0c;解压镜像压缩文件 3&#xff0c;运行setup.exe 4&#xff0c;开始安装 5&#xff0c;不要运行软件…

Python环境下基于深度学习的旋转机械故障诊断及其权重可视化

随着神经网络所要完成的任务越来越智能化&#xff0c;其内部的结构也变得越来越复杂&#xff0c;神经网络学到的解题方法也越来越难以被人类所理解。神经网络的内部单元就好比一个“黑箱”&#xff0c;虽然这种处理方法能够在某种程度上达到非常不错的效果&#xff0c;但其原因…

同城外卖多商户点餐系统平台开发JAVA版源码跑腿小程序APP

项目背景 在快节奏的现代生活中&#xff0c;人们对于时间的需求愈发敏感。如何在忙碌中兼顾生活与工作&#xff0c;如何在繁杂琐事中找到一丝便利&#xff0c;这已然成为众多都市人共同关心的议题。在这样的背景下&#xff0c;同城外卖跑腿系统软件应运而生&#xff0c;以其高…

Modbus转Profinet网关快速解决PLC插槽数量不够用的烦恼

通过Modbus转Profinet&#xff08;XD-MDPN100&#xff09;网关的应用&#xff0c;不仅可以实现Modbus设备与Profinet网络的平滑对接&#xff0c;还能有效解决PLC插槽限制和Modbus指令轮询等问题&#xff0c;Modbus转Profinet网关&#xff08;XD-MDPN100&#xff09;在解决PLC插…

Etcd 基本入门

1&#xff1a;什么是 Etcd ? Etcd 是 CoreOS 团队于2013年6月发起的开源项目&#xff0c;它的目标是构建一个高可用的分布式键值(key-value)数据库。etcd内部采用raft协议作为一致性算法&#xff0c;Etcd基于 Go 语言实现。 名字由来&#xff0c;它源于两个方面&#xff0c;…

java将文件转成流文件返回给前端

环境&#xff1a;jdk1.8&#xff0c;springboot2.5.3,项目端口号&#xff1a;9100 1.待转换的文件 一、路径 二、文件内容 2.controller中代码 package com.example.pdf.controller;import com.example.pdf.service.GetFileStreamService; import org.springframework.web.b…

嵌入式linux学习之交叉编译器安装

交叉编译器介绍 ARM 裸机、Uboot 移植、Linux 移植这些都需要在 Ubuntu 下进行编译&#xff0c;编译就需要编译器&#xff0c;在 Liux 进行 C 语言开发里面使用 GCC 编译器进行代码编译&#xff0c;但是 Ubuntu 自带的 gcc 编译器是针对 X86 架构的&#xff01;而我们现在要编…

封装性练习

练习 1 &#xff1a; 创建程序&#xff1a;在其中定义两个类&#xff1a; Person 和 PersonTest 类。定义如下&#xff1a; 用 setAge() 设置人的合法年龄 (0~130) &#xff0c;用 getAge() 返回人的年龄。在 PersonTest 类中实例化 Person 类的对象 b &#xff0c;调用 set…

需要本地后端的真机调试-微信

打开和修改IP改为电脑与手机同一局域网的 不知道这个要不要

利用计算机视觉技术打造直播美颜工具:详解美颜SDK开发

本篇文章&#xff0c;小编将详解如何利用计算机视觉技术打造直播美颜工具&#xff0c;并深入探讨美颜SDK的开发过程。 一、美颜技术概述 在直播美颜工具中&#xff0c;美颜技术起到了至关重要的作用。美颜技术通过对图像进行实时处理&#xff0c;改善主播或用户的外观&#x…

C++——vector类及其模拟实现

前言&#xff1a;前边我们进行的string类的方法及其模拟实现的讲解。这篇文章将继续进行C的另一个常用类——vector。 一.什么是vector vector和string一样&#xff0c;隶属于C中STL标准模板库中的一个自定义数据类型&#xff0c;实际上就是线性表。两者之间有着很多相似&…

嵌入式3-29

今日作业&#xff1a;用fwrite 和 fseek功能&#xff0c;将一张bmp格式的图片更改成 德国国旗#include <stdio.h> #include <string.h> #include <stdlib.h> #include <math.h> typedef unsigned char bgr[3]; int main(int argc, const char *argv[])…

基于JSPM的美食推荐管理系统

背景 互联网的迅猛扩张彻底转变了全球各类组织的运营模式。自20世纪90年代起&#xff0c;中国各级政府和企事业单位便开始探索运用网络系统来处理管理事务。然而&#xff0c;早期的网络覆盖不广、用户接受度不高、相关网络法规不健全以及技术发展不成熟等因素&#xff0c;都曾…

Vue-vue3

一、Vue3简介二、Vue3有那些优化性能的提升源码升级拥抱TypeScript新的特性 三、创建Vue3.0工程四、Vue3工程结构&#xff08;使用cli创建的vue3&#xff09;五、常用的Composition API&#xff08;组合式API&#xff09;setupsetup的两个注意点 ref函数reactive函数Vue3.0中的…

鸿蒙原生应用开发-网络管理HTTP数据请求

一、场景介绍 应用通过HTTP发起一个数据请求&#xff0c;支持常见的GET、POST、OPTIONS、HEAD、PUT、DELETE、TRACE、CONNECT方法。 二、接口说明 HTTP数据请求功能主要由http模块提供。 使用该功能需要申请ohos.permission.INTERNET权限。 涉及的接口如下表&#xff0c;具体的…

C/C++中重载函数取地址的方法

目录 1.现象 2.指定参数取函数地址 3.利用Qt的类QOverload 1.现象 函数重载在C/C编码中是非常常见的&#xff0c;但是我们在std::bind或std::function绑定函数地址的时候&#xff0c;直接取地址&#xff0c;程序编译就会报错&#xff0c;示例如下&#xff1a; class CFunc1…

2024年妈妈杯数学建模思路A题B题C题D题思路分享

文章目录 1 赛题思路2 比赛日期和时间3 组织机构4 建模常见问题类型4.1 分类问题4.2 优化问题4.3 预测问题4.4 评价问题 5 建模资料 1 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 2 比赛日期和时间 报名截止时间&#xff1a;2024…

鸿蒙迎来大爆发,有必要转行鸿蒙开发吗?

鸿蒙系统&#xff0c;作为华为自主研发的操作系统&#xff0c;正在迎来前所未有的大爆发&#xff0c;以强大的分布式技术和创新能力&#xff0c;不仅支持多种终端设备&#xff0c;更在构建一个日益完善的生态系统&#xff0c;在当前的科技浪潮中。面对这样的发展趋势&#xff0…