Nuxt2 渲染时html比css加载快,导致闪屏/CSS样式迟滞/抖动问题记录

本文主要是介绍Nuxt2 渲染时html比css加载快,导致闪屏/CSS样式迟滞/抖动问题记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

问题场景:

最近在用Nuxt2重写公司官网,但因为笔者不是专业前端,之前虽然也用vue2来写前端,但是用nuxt2来写项目还是第一次。在开发过程中虽然也磕磕碰碰,但因为开发的是官网,偏CMS型的网站,所以没有太多JS层面的问题,主要是CSS问题比较多要慢慢调。然而在我开发完成部署预发环境时,发现在刷新页面时会出现严重的闪屏或称为页面CSS样式抖动现象

具体表现:

在刷新页面时先加载出HTML代码,此时页面就是一个完全没样式的很丑的纯html页面,要等0.5秒-1秒后才加载出CSS样式并渲染出最终带样式的页面。这一闪而过的纯html就很难受了,也非常影响用户体验

尝试解决:

第一次尝试

开始时我怀疑是首屏性能问题,在vue的开发中也遇过,但是主要的异常现象表现是白屏,白屏1-3秒才出现页面。我尝试把asyncData中的全部请求都注释掉,然后重新打包运行,刷新页面时,通过F12查看页面加载时间从500ms降低到150ms了,但是发现依然存在上述的闪屏现象。所以判断并不是因为asyncData中请求太多/太慢导致的。

第二次尝试

既然不是页面的asyncData中的请求导致的。我就开始检查是否配置问题导致,因为我公司刚好有另外一个也是用nuxt2写的项目(不是我开发的),所以就参照着来检查nuxt.config.js文件,发现几乎没什么差别,连package.json的依赖都差不多。我后面甚至把package.json的依赖和nuxt.config.js文件的关键配置都改成一样,还是不行。所以判断不是package.json的依赖和nuxt.config.js文件配置问题

第三次尝试

经过上面的尝试后,实在搞不明白,所以就尝试面向百度编程,在百度搜索了一轮发现的确有几个相关的技术博客,提到的解决方案都差不多,都是说配置extractCSS,在此列举一下我能找到的几个关于这个问题的技术博客:
https://blog.csdn.net/weixin_42224055/article/details/106053404
https://juejin.cn/post/6946080450330755102
但因为我比对过我正在写的项目和公司另外一个nuxt项目的文件的配置文件,认为不是这个问题,但是这时也只能死马当活马医,就尝试了一下,发现依然是不行,所以判断不是extractCSS的原因。

最终解决方案

最后实在没有办法,只能创建一个新的空白的nuxt2项目,然后把我的项目目录、文件、代码一部分一部分的复制过来,看看是从哪一步开始出问题。幸亏我的代码不多,最后终于找到问题的原因! 问题是出在根目录的app.html文件中,根据nuxt2的官方手册,app.html一般不需要手动创建的,nuxt在运行时会自动创建,而且通常这个文件也不需要改动的。

关于app.html的描述详见官方手册的这个章节
在这里插入图片描述

如需引入额外的js或css文件,可以通过nuxt.config.js来配置(官方也推荐这样配置),而需要模板也可以通过layouts目录中自定义模板实现,完全不需要手动在根目录创建或者修改app.html的。而我是因为最开始的时候不熟悉nuxt2,看了官方手册关于介绍目录结构的章节后,自己理解错误,套用了vue的开发理念,所以就手多在根目录创建了app.html。在我删除app.html后,终于解决了闪屏问题。

结语

所以开发nuxt2时如遇同样出现闪屏现象的同学可以检查一下自己是不是在根目录下创建了app.html这个文件。写这篇文章主要是这个坑可能太小众了(大部分人都不会这么闲,手多在根目录手动创建一个app.html),我找遍了百度和bing,都没找到解决方案,最后只能通过创建一个新nuxt项目的方式一点点排查,花了几小时才最终排查出问题。所以在此记录一下,也希望能帮到其他遇到同样问题的同学。但本人因为不是专业前端,对nuxt也不熟悉,只查到是app.html文件的问题,最终也无法查出底层原理是什么,如果有知道的同学也欢迎告诉我,谢谢!

这篇关于Nuxt2 渲染时html比css加载快,导致闪屏/CSS样式迟滞/抖动问题记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)

《java中pdf模版填充表单踩坑实战记录(itextPdf、openPdf、pdfbox)》:本文主要介绍java中pdf模版填充表单踩坑的相关资料,OpenPDF、iText、PDFBox是三... 目录准备Pdf模版方法1:itextpdf7填充表单(1)加入依赖(2)代码(3)遇到的问题方法2:pd

解决RocketMQ的幂等性问题

《解决RocketMQ的幂等性问题》重复消费因调用链路长、消息发送超时或消费者故障导致,通过生产者消息查询、Redis缓存及消费者唯一主键可以确保幂等性,避免重复处理,本文主要介绍了解决RocketM... 目录造成重复消费的原因解决方法生产者端消费者端代码实现造成重复消费的原因当系统的调用链路比较长的时

深度解析Nginx日志分析与499状态码问题解决

《深度解析Nginx日志分析与499状态码问题解决》在Web服务器运维和性能优化过程中,Nginx日志是排查问题的重要依据,本文将围绕Nginx日志分析、499状态码的成因、排查方法及解决方案展开讨论... 目录前言1. Nginx日志基础1.1 Nginx日志存放位置1.2 Nginx日志格式2. 499

kkFileView启动报错:报错2003端口占用的问题及解决

《kkFileView启动报错:报错2003端口占用的问题及解决》kkFileView启动报错因office组件2003端口未关闭,解决:查杀占用端口的进程,终止Java进程,使用shutdown.s... 目录原因解决总结kkFileViewjavascript启动报错启动office组件失败,请检查of

SpringBoot 异常处理/自定义格式校验的问题实例详解

《SpringBoot异常处理/自定义格式校验的问题实例详解》文章探讨SpringBoot中自定义注解校验问题,区分参数级与类级约束触发的异常类型,建议通过@RestControllerAdvice... 目录1. 问题简要描述2. 异常触发1) 参数级别约束2) 类级别约束3. 异常处理1) 字段级别约束

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

Spring的RedisTemplate的json反序列泛型丢失问题解决

《Spring的RedisTemplate的json反序列泛型丢失问题解决》本文主要介绍了SpringRedisTemplate中使用JSON序列化时泛型信息丢失的问题及其提出三种解决方案,可以根据性... 目录背景解决方案方案一方案二方案三总结背景在使用RedisTemplate操作redis时我们针对