news 2026/6/10 13:41:04

[css特性]HTML Learn Data Day 3

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[css特性]HTML Learn Data Day 3

这两天真有点忙,期末的实验最难做了!

了解了css的一些特性,一直没觉得css没多难,但是学着学着发现,选择器这东西像是石山

尤其是选择器权重更是重量级的石山,就没有更简单一点的办法?

有没有懂的能告诉我?

选择器

1. 复合选择器

复合选择器是由两个或多个基础选择器,通过特定的方式组合而成,用于更精准地定位 HTML 元素。

  • 后代选择器 (Descendant Selector):用空格隔开(如.box p),选择父元素内所有的后代元素。
  • 子代选择器 (Child Selector):用>隔开(如.box > p),只选择亲儿子层级的元素。
  • 并集选择器 (Union Selector):用逗号,隔开,集体声明,多个选择器共享同一套样式。
  • 交集选择器 (Intersection Selector):紧密相连(如div.red),既是 div 又是 .red 的元素(注意:标签名必须写在前面)。

2. 伪类选择器 (Pseudo-classes)

伪类本质上是用来描述元素处于某种特定状态的类。

链接伪类(遵循 LVHA 顺序编写):

  • :link:未访问的链接状态。
  • :visited:已访问后的链接状态。
  • :hover:鼠标悬停状态(最常用)。
  • :active:鼠标点击按下但未松开的状态。

补充知识:除了链接,还有结构伪类(如:first-child,:nth-child(n))和行为伪类(如:focus焦点状态),它们在布局中也非常高效。

CSS 三大特性

1. 继承性

子元素会继承父元素的某些样式。

  • 哪些能继承:主要是文本相关的属性,如font-size,font-family,color,line-height,text-align
  • 哪些不能继承:布局相关的属性,如margin,padding,border,width,height等。

2. 层叠性

当同一个元素被设置了多个相同的属性时,CSS 的冲突处理机制。

  • 如果选择器权重相同,则遵循就近原则:写在 CSS 样式表下方的属性会覆盖上方的属性。

3. 优先级/权重

优先级决定了哪条规则最终生效。我们可以用一套“权重权重计分表”来快速判断:

选择器类型权重权重(数值表示)说明
!important∞\infty(无穷大)强制生效,尽量少用
行内样式(1,0,0,0)(1, 0, 0, 0)(1,0,0,0)写在标签style属性里
ID 选择器(0,1,0,0)(0, 1, 0, 0)(0,1,0,0)#header
类/伪类/属性选择器(0,0,1,0)(0, 0, 1, 0)(0,0,1,0).content,:hover
标签选择器(0,0,0,1)(0, 0, 0, 1)(0,0,0,1)div,p
通配符/继承(0,0,0,0)(0, 0, 0, 0)(0,0,0,0)*权重最低
  • 口诀:选中的范围越精确,优先级越高。
  • 复合选择器计算:权重会累加。例如nav ul li的权重是0,0,0,30,0,0,30,0,0,3;而.nav ul li0,0,1,20,0,1,20,0,1,2。后者胜出。

背景属性

CSS 的background属性不仅能设置颜色,还能精细控制图片的显示。

CSS

.the-image{width:300px;height:300px;background-color:pink;/* 背景颜色 */background-image:url(../image/cuteReisentyan.jpg);/* 背景图片路径 */background-repeat:no-repeat;/* 不平铺/不重复 */background-size:contain;/* 图片缩放模式:cover(充满) 或 contain(完整显示) */background-position:center center;/* 图片水平垂直居中 */background-attachment:fixed;/* 背景固定,不随页面滚动 */}

补充:背景复合写法(Shorthand)为了简化代码,通常写成一行:background: 背景颜色 背景图片地址 背景平铺 背景滚动 背景位置 / 背景尺寸;(注:背景尺寸必须紧跟在位置后面并用斜杠隔开)

元素显示模式 (Display Mode)

理解显示模式是掌握网页布局(尤其是后续 Flex 布局)的前提。

  1. 块级元素 (Block-level)
    • 代表div,h1~h6,p,ul,li
    • 特点:独占一行;宽度默认是父级 100%;可以设置宽、高、内外边距。
  2. 行内元素 (Inline)
    • 代表span,a,i,em
    • 特点:一行可以显示多个;设置宽高无效;大小由内容撑开。
  3. 行内块元素 (Inline-block)
    • 代表img,input,td
    • 特点:一行显示多个,但可以设置宽高和内外边距。

模式转换:使用display属性

  • display: block;:转换为块级(常用:让<a>标签可设置宽高)。
  • display: inline;:转换为行内。
  • display: inline-block;:转换为行内块。
  • display: none;隐藏元素(不占位)。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/10 12:24:56

单元测试中的Mock技术:Mockito与PowerMock深度对比

在当今追求高质高效交付的软件开发领域&#xff0c;单元测试是保障代码质量的基石。而Mock技术&#xff0c;作为隔离被测对象、模拟复杂依赖的关键手段&#xff0c;已成为测试从业者工具箱中的必备品。在众多Mock框架中&#xff0c;Mockito与PowerMock因其强大的功能和广泛的社…

作者头像 李华
网站建设 2026/6/10 12:39:43

如何处理时间序列异常值

原文&#xff1a;towardsdatascience.com/how-to-deal-with-time-series-outliers-28b217c7f6c2 在本文中&#xff0c;我们将探讨&#xff1a; 不同类型的时间序列异常值 基于预测和估计的异常值检测方法 如何使用替换处理不想要的异常值 异常值的类型 异常值是显著偏离正常…

作者头像 李华
网站建设 2026/4/30 21:34:30

跨国项目中的测试挑战:时差、文化差异与质量标准的统一

跨国测试的新常态‌随着业务的国际化扩张和分布式团队模式的普及&#xff0c;软件项目的生命周期早已跨越国界。测试团队不再局限于同一办公室内协作&#xff0c;而是需要与分布在不同时区、拥有不同文化背景的成员共同工作。这种模式极大地扩展了人才库和工作效率&#xff0c;…

作者头像 李华