CSS3 伪元素(Pseudo-elements)大全

CSS3 伪元素(Pseudo-elements)大全

CSS3 伪元素用于选择元素的特定部分,以双冒号 :: 开头(CSS3 规范推荐写法,但单冒号 : 也支持以保持向后兼容)。

主要 CSS3 伪元素列表

  1. ::before

    在元素内容前插入生成的内容

    css 复制代码
    p::before { content: "→ "; }
  2. ::after

    在元素内容后插入生成的内容

    css 复制代码
    p::after { content: " ←"; }
  3. ::first-letter

    选择块级元素的首字母

    css 复制代码
    p::first-letter { font-size: 2em; }
  4. ::first-line

    选择块级元素的第一行

    css 复制代码
    p::first-line { font-weight: bold; }
  5. ::selection

    选择用户选中的文本部分

    css 复制代码
    ::selection { background: yellow; }
  6. ::placeholder

    选择表单元素的占位文本

    css 复制代码
    input::placeholder { color: #999; }
  7. ::backdrop

    全屏元素后面的背景层

    css 复制代码
    video::backdrop { background: black; }
  8. ::marker (CSS3 新增)

    选择列表项的标记(如 <li> 的项目符号)

    css 复制代码
    li::marker { color: red; }
  9. ::spelling-error (实验性)

    标记浏览器检测到的拼写错误文本

    css 复制代码
    ::spelling-error { text-decoration: wavy red underline; }
  10. ::grammar-error (实验性)

    标记浏览器检测到的语法错误文本

    css 复制代码
    ::grammar-error { text-decoration: wavy green underline; }

注意事项

  1. 单冒号 vs 双冒号

    • 单冒号是CSS2的写法,CSS3 规范推荐使用 ::(如 ::before
    • 但浏览器也支持 : 写法(如 :before)以保持兼容性
    • 唯一例外是 :before:after:first-letter:first-line 在 CSS2 中已存在
  2. 必须设置 content 属性

    css 复制代码
    .box::before {
      content: ""; /* 必须设置,即使是空字符串 */
      display: block;
      width: 20px;
    }
  3. 伪元素组合使用

    css 复制代码
    blockquote::first-letter::after {
      content: "'";
      color: red;
    }
  4. 浏览器兼容性

    • 大多数现代浏览器支持所有标准伪元素
    • ::marker 在旧浏览器中支持有限
    • ::spelling-error::grammar-error 仍处于实验阶段

实际应用示例

css 复制代码
/* 自定义列表标记 */
ul li::marker {
  content: "✓ ";
  color: green;
}

/* 输入框清除按钮样式 */
input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  height: 1em;
  width: 1em;
  background: url(close.svg) no-repeat;
}

/* 首行首字母特殊样式 */
article p::first-line {
  font-variant: small-caps;
}
article p::first-letter {
  font-size: 3em;
  float: left;
  line-height: 1;
}
相关推荐
Csvn8 分钟前
`??` 和 `||` 搞混,线上用户头像全挂了
前端
kyriewen34 分钟前
白宫前脚下了限制令,OpenAI 后脚就把 GPT-5.6 发了
前端·gpt·openai
用户40269244819081 小时前
CRMEB Pro 新增后台接口全链路:路由、权限、验证器、返回格式一次讲清
前端·后端
泉城老铁2 小时前
springboot+vue+ ffmpeg 实现视频的拉流播放
前端
PedroQue992 小时前
uni-router v1.8.0新增冷启动守卫补执行
前端·uni-app
xiaok2 小时前
部署之后,本地浏览器还在读取旧缓存导致页面一直显示loading中
前端
用户059540174462 小时前
Redis缓存一致性踩坑实录:线上故障排查6小时,我用pytest+内存快照把它永久关进了笼子
前端·css
星栈2 小时前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:第一版先把列表和详情跑通
前端·rust·前端框架
用户1733598075373 小时前
Vue 3 SPA 首屏优化:从 3s 到 1.2s 的 5 个实践
前端·vue.js
咖啡无伴侣3 小时前
基础骨架:30 分钟搭好 pnpm workspace,完成双项目 Monorepo 迁入
前端