伪类与伪元素

伪类和伪元素的本质区别是修饰的东西是否能在DOM中找到对应的真实节点,比如伪类:first-of-type修饰的是一个能找到的真实节点,而伪元素::first-line修饰的不是一个真实的节点而是一段文本的一行

伪类:

伪类以单个冒号(:)开头,用于在元素特定状态为他添加样式(注意伪类本身不决定是否回流/重绘,看你伪类把样式改变了什么)

常见伪类:

  1. 动态伪类: :link 未访问的链接 / :visited 已访问的链接 / :hover 鼠标悬停的元素 / :active 被激活的元素(如鼠标按下的瞬间) / :focus 获得焦点的元素(比如输入框点击后)
  2. 结构伪类(根据DOM树中的位置筛选): :first-child 父元素第一个子元素 / :last-child / :nth-child(n) 父元素第n个子元素(n可以是数字或关键字,比如odd奇数或even偶数) / :first-of-type 同类型第一个 / :last-of-type / :nth-of-type(n) 同类型第n个
  3. 表单相关: :enabled 可用的输入框 / :disabled 禁用的输入框 / :checked 选中的单选或复选框 / :required 必填输入框 / :valid 通过验证的输入框 / :invalid未通过验证的输入框

:first-of-type 同类型第一个 / :last-of-type / :nth-of-type(n) 同类型第n个:

  1. 只能用于标签,因为类型是根据标签判断的
  2. 注意如果单独用表示父元素的子元素(子孙元素)选中每种标签的第一个,比如div :first-of-type(中间有空格,选中的不是div,div是父元素)表示div的子孙元素中,每种不同类型元素的第一个都被选中,而用于元素表示父元素的该标签子元素的第一个如div:first-of-type表示父元素的第一个div标签
  3. 浏览器解析的时候会先忽略class,id这些,解析完这个之后再加上class这些,比如div.container:first-of-type浏览器会找到父元素的第一个div元素,然后看看上面有没有container,没有就不选

伪元素

伪元素以双冒号(::)开头,但是为了兼容旧浏览器单冒号也行,用于样式化元素的特定部分,或创造一个不在html中的虚拟元素,会渲染在CSSOM和layout中,但不会渲染在dom中

注意:

  1. 伪元素默认是内联元素,所以如果要当作块级元素渲染需要设置display
  2. 伪元素即使没内容也一定要设置content:'',否则伪元素压根不会被渲染

常见伪元素:

  1. ::before : 作为元素的开头子元素插入(常与content属性配合,即用content来指定插入的内容)
  2. ::after : 作为元素的结束族元素插入(常与content属性配合)
  3. ::first-line : 选择块级元素的第一行文本
  4. ::first-letter : 选择块级元素的第一个字母
  5. ::placeholder : 样式化输入框的占位文本
  6. ::selection : 样式化用户鼠标选中的文本部分
相关推荐
午安~婉2 小时前
Electron桌面应用(续2)
前端·javascript·electron·路由守卫·优化llm返回的内容
eEKI DAND2 小时前
一个比 Nginx 还简单的 Web 服务器
服务器·前端·nginx
weixin_443478512 小时前
Flutter学习之自定义组件
javascript·学习·flutter
Highcharts.js9 小时前
Highcharts 云端渲染的真相:交互式图表与服务器端生成的边界
前端·信息可视化·服务器渲染·highcharts·图表渲染
zhuyan10810 小时前
Linux 系统磁盘爆满导致无法启动修复指南
前端·chrome
编程牛马姐11 小时前
独立站SEO流量增长:提高Google排名的优化方法
前端·javascript·网络
NotFound48611 小时前
实战指南如何实现Java Web 拦截机制:Filter 与 Interceptor 深度分享
java·开发语言·前端
Dontla11 小时前
高基数(High Cardinality)问题介绍(Prometheus、高基数字段、低基数字段)
前端·数据库·prometheus
whuhewei14 小时前
为什么客户端不存在跨域问题
前端·安全