CSS `Specificity` (特异性) 深度:计算规则与优先级冲突解决

各位观众老爷,晚上好!我是今天的主讲人,咱们今天聊点硬核的——CSS 的“特异性”。别怕,这玩意儿听起来吓人,其实就是 CSS 优先级的大 boss。掌握了它,你就能在样式大战中运筹帷幄,告别“样式覆盖覆盖再覆盖”的噩梦。 开场白:CSS 的世界,谁说了算? 话说,你写了一堆 CSS 样式,结果浏览器愣是不听你的,非要用它自己的,或者用别的 CSS 文件里的。这时候,你是不是想掀桌?别急,这锅不能全甩给浏览器,很可能是你没搞清楚 CSS 的“特异性”。 想象一下,CSS 就像一个民主社会,每个样式声明都有投票权。但不是一人一票,而是根据“特异性”来决定投票权重。权重高的,说了算! 第一幕:特异性是个啥? 简单来说,特异性就是浏览器用来判断哪个 CSS 规则应该应用的算法。它基于你选择器写的有多“具体”来给每个规则打分。分数越高,优先级越高,样式就越会被应用。 第二幕:特异性计算规则——“四个维度,层层递进” 特异性计算规则就像一个四维坐标系,每个维度代表一种选择器的类型,从高到低依次是: 内联样式 (Inline styles): 直接写在 HTML 标签里的 style 属性里的样式 …