使用 preload+onload 是推荐的异步加载 CSS 方案,通过 rel="preload" 高优先级下载不阻塞渲染,在 onload 时改为 rel="stylesheet" 启用样式,结合动态创建 link 可实现非阻塞且可控的加载时机,避免页面闪动。

通过 link 标签异步加载 CSS,核心思路是避免阻塞页面渲染的同时,确保样式最终生效。标准的 link 标签会阻塞渲染直到 CSS 下载完成,而异步加载可以通过一些技巧绕过这种阻塞行为。
示例代码:
<link
rel="preload"
href="styles.css"
as="style"
onload="this.onload=null;this.rel='stylesheet'">
<script>
// 防止 preload 资源未及时处理
function loadCSS(href) {
var link = document.createElement('link');
link.rel = 'stylesheet';
link.href = href;
document.head.appendChild(link);
}
// 可用于补漏或动态加载
</script>示例代码:
<script>
function loadCSS(href) {
var link = document.createElement('link');
link.rel = 'stylesheet';
link.href = href;
document.head.appendChild(link);
}
// 页面加载后调用
loadCSS('styles.css');
</script>示例:
立即学习“前端免费学习笔记(深入)”;
<link rel="stylesheet" href="print.css" media="print" onload="if(media!='all')media='all'">
基本上就这些方法。推荐使用 preload + onload 方案,兼容性较好且能利用浏览器预加载机制。关键是不让 CSS 阻塞首次渲染,又能尽快应用样式,避免页面闪动。不复杂但容易忽略细节,比如事件去重和错误处理。
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号