0

0

css通过JS动态加载样式表如何实现_使用JavaScript控制样式加载时机

P粉602998670

P粉602998670

发布时间:2026-02-21 14:00:20

|

261人浏览过

|

来源于php中文网

原创

动态创建并插入标签加载css最直接,需挂载到才生效;可监听onload/onerror处理状态;insertrule()适合注入少量样式;用预设class配合onload可缓解fouc。

css通过js动态加载样式表如何实现_使用javascript控制样式加载时机

动态创建 <link> 标签并插入 DOM

最直接的方式是用 JavaScript 创建 <link> 元素,设置 rel="stylesheet"href,再插入到 中。浏览器会立即发起请求并应用样式。

关键点:

  • link 必须在插入 DOM 后才开始加载,不能只创建不挂载
  • 推荐插入到 末尾,避免阻塞渲染(相比 开头更安全)
  • 插入前可检查是否已存在同名样式表,避免重复加载
function loadCSS(url) {
  if (document.querySelector(`link[href="${url}"]`)) return;
  const link = document.createElement('link');
  link.rel = 'stylesheet';
  link.href = url;
  document.head.appendChild(link);
}
loadCSS('/styles/theme-dark.css');

监听 link.onloadlink.onerror 处理加载状态

样式表加载是异步的,但 <link> 元素支持 onloadonerror 事件(现代浏览器均支持,IE9+)。不能依赖 onload 来判断样式“已生效”,因为样式计算和重排可能稍有延迟。

常见误用:

立即学习Java免费学习笔记(深入)”;

Summarizer
Summarizer

基于 AI 的文本段落摘要生成器

下载
  • onload 当作“样式已就绪可操作 DOM”的信号 —— 实际上此时 CSSOM 可能刚构建完,但未参与渲染流程
  • 忽略 onerror,导致 404 样式表静默失败,UI 异常无提示
const link = document.createElement('link');
link.rel = 'stylesheet';
link.href = '/styles/animation.css';
link.onload = () => console.log('CSS loaded');
link.onerror = () => console.error('Failed to load CSS:', link.href);
document.head.appendChild(link);

CSSStyleSheet.insertRule() 动态注入规则(无需网络请求)

如果只是追加少量样式(比如主题色、响应式断点调整),比加载外部文件更快更可控。需先获取或创建一个 CSSStyleSheet 对象。

注意兼容性细节:

  • document.styleSheets 是只读类数组,但可通过 document.styleSheets[i].insertRule() 修改已有表
  • 新建 <style></style> 并插入 DOM 是最兼容方式;CSSStyleSheet 构造函数(new CSSStyleSheet())仅在 Chrome 85+/Firefox 94+ 支持
  • insertRule() 的第二个参数是插入位置索引,传 0 表示最前,省略则默认追加到末尾
const style = document.createElement('style');
document.head.appendChild(style);
const sheet = style.sheet;
sheet.insertRule('.btn { background: #007bff; }', 0);
sheet.insertRule('.btn:hover { opacity: 0.8; }');

避免 FOUC 和样式闪烁的时机控制技巧

动态加载 CSS 最容易暴露的问题是 FOUC(Flash of Unstyled Content):页面先按无样式渲染,样式到位后突然跳变。这不是 JS 能完全消除的,但可以缓解。

有效做法:

  • 上预先加一个 class(如 loading-css),初始 CSS 隐藏关键区域或设占位样式
  • link.onload 触发后移除该 class,并可配合 requestAnimationFrame 确保样式应用后再操作 DOM
  • 慎用 link.disabled = true 控制启用时机 —— 它只禁用样式应用,不中断下载,且 IE 不支持

真正难处理的是跨域样式表(Cross-Origin)的 onload 事件不可靠,此时只能靠定时检测 document.styleSheets 长度或尝试读取规则数量(受限于 CORS 策略),实际项目中应尽量避免跨域 CSS 动态加载。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

970

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

797

2023.11.06

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

686

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

22

2025.12.06

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

524

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

434

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

595

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5712

2023.08.17

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

796

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.4万人学习

CSS教程
CSS教程

共754课时 | 34.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号