伪类与伪元素

伪类和伪元素的本质区别是修饰的东西是否能在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 : 样式化用户鼠标选中的文本部分
相关推荐
哀木13 小时前
一个简单的套壳方案,就能让你的 Agent 少做重复初始化
前端
问心无愧051314 小时前
ctf show web入门27
前端
小村儿14 小时前
给 AI Agent 装上"长期记忆":Karpathy 的 LLM Wiki 思想,我做成了工具
前端·后端·ai编程
竹林81814 小时前
用ethers.js连接MetaMask实现Web3钱包登录:从踩坑到稳定运行的完整记录
前端·javascript
heyCHEEMS14 小时前
如何用 Recast 实现静态配置文件源码级读写
前端·node.js
心连欣14 小时前
从零开始,学习所有指令!
前端·javascript·vue.js
review4454314 小时前
大模型和function calling分别是如何工作的
前端
东东同学14 小时前
耗时一个月,我把 Nuxt 首屏性能排障经验做成了一个 AI Skill
前端·agent
冴羽15 小时前
超越 Vibe Coding —— AI 辅助编程指南
前端·ai编程·vibecoding
梦想的颜色15 小时前
一天一个SKILL——前端最佳自动化测试 webapp-testing
前端·web app