<style>标签必须放在<head>里,否则样式可能不生效或导致FOUC闪屏;浏览器自上而下解析HTML,<style>仅被HTML5规范允许作为<head>的子元素,塞入<body>无论开头或结尾均违反标准、破坏渲染流程且不可靠。
浏览器解析 HTML 是自上而下流式进行的。<style> 标签必须出现在 <head> 内部,不能塞进 <body> 里,哪怕只放一行。这不是“推荐”,而是 HTML5 规范明确限定的合法位置——<style> 只被允许作为 <head> 的子元素。
常见错误现象包括:页面刚打开时文字正常,0.1 秒后突然跳变颜色/间距;DevTools 里能看到 CSS 规则已加载,但某些元素始终没应用;Safari 或旧版 Chrome 中样式完全失效。
Element style not allowed as child of element body
<body> 中的 <style>,导致首屏无样式放在 <body> 开头(比如紧接 <body> 标签后),看似能早一点声明样式,实际反而破坏渲染流程:浏览器已开始解析并构建 DOM,此时插入 <style> 会导致样式引擎回溯重算,性能更差;且仍无法参与首屏布局计算。
放在 </body> 前,问题更明显:所有 <body> 内容都已渲染完毕,再加载样式就会造成 FOUC(Flash of Unstyled Content)——用户先看到裸 HTML,再突然重绘,体验断裂。
立即学习“前端免费学习笔记(深入)”;
style 属性,不是 <style> 标签<style scoped> 是编译产物,运行时仍注入到 <head>,不是直接塞进 <body>
<div> ——那是违反语义的 hack<style> 应紧贴 <title> 后或 <meta> 组之后,避免被其他元信息干扰。它不支持 defer 或 async,本身就是同步阻塞解析的资源。
type="text/css" 可省略,加了不报错但冗余--main-color)、媒体查询、@keyframes,但禁用 @import(会额外阻塞请求)url(./assets/icon.png),浏览器按当前 HTML URL 解析,不是文件系统路径<style> 块按顺序层叠,后写的同优先级规则会覆盖前面的很多时候不是位置错了,而是其他细节触发了静默失败。最典型的是:HTML 注释或非法字符混在 <style> 和 </style> 之间,CSS 解析器遇到第一个非法 token 就停,整个块被丢弃。
<style> 默认只作用于 light DOM,不穿透到 shadow rootscoped 却没配对应构建 loader(如 Vue 的 vue-style-loader),样式会被移除或忽略style 属性(特异性 1000)永远高于 <style> 中任何选择器(如 p 是 1),!important 也不能跨层级翻盘真正要检查的,从来不只是“放哪了”,而是“有没有被解析”“有没有被覆盖”“有没有被隔离”。