CSS 选择器的几种方法

CSS 选择器的几种方法

业余选手爱记笔记

CSS权威指南(第四版)是一本好书,看了一遍第二章的选择符有些受益,记录一点读后感和练习。我已将该书电子版的PDF书签整理完善,供大家下载:

CSS权威指南中文第四版 PDF电子版下载详见 https://download.csdn.net

示例代码

在多个按钮之间,加一个竖向管道 | 分隔符,按钮的个数是变化的,示例图如下,现在需要将第 2 到第 n 个按钮前加左边框,用 css 选择器有哪几种方法?

html 示例代码:

html 复制代码
 <!DOCTYPE html>
<html lang="zh-cn">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>选择器练习</title>
    <style>
        #nav>li { width: 100px; display: inline-block; text-align: center; }
        #nav>li>a { text-decoration: none; color: inherit; }
        #nav>li>a:hover, #nav>li>a:focus { color: #f30327; font-weight: 700; }
    </style>
</head>
<body>
    <p>示例:在按钮之间添加一个分隔符</p>
    <ul id="nav">
        <li id="btn1"><a href="#mon">张三</a></li>
        <li id="btn2"><a href="#tues">李四</a></li>
        <li id="btn3"><a href="#wen">王麻子</a></li>
    </ul>
</body>
</html>

用否定伪类+伪元素

  1. 不选择 ul 的第一个子代,用伪元素 :first-child
css 复制代码
li:not(li:first-child) {border-left: 1px solid #ccc;}
  1. 不选择 ul 的第一个子代,用伪元素 :nth-child(1),指定第1个li
css 复制代码
li:not(li:nth-child(1)) {border-left: 1px solid #ccc;}
  1. 不选择 id 为 btn1 的 li,需要标记列表 id
css 复制代码
li:not(#btn1) {border-left: 1px solid #ccc;}

用代数式法

  1. 选择 li 元素,并从第 2 个开始,n=0,1,2...
css 复制代码
li:nth-child(n+2) {border-left: 1px solid #ccc;}

同胞选择符 ~

  1. 选择 id 为 btn1 的同胞元素,btn1 是第一个按钮,他的同胞就是其他按钮
css 复制代码
#btn1~li {border-left: 1px solid #ccc;}
  1. 不用 id 选择器也可以,因为第一个按钮也是 li 元素,可以用如下写法
css 复制代码
li~li {border-left: 1px solid #ccc;}

相邻同胞选择符 +

  1. 看起来和第6种方法很相似,但他们是有区别的,前一个 li 并不特指第一个按钮。如果你有怀疑,可以用 #btn1+li 选择符测试,结果只是在第 1 个和第 2 个按钮之间添加了分隔符
css 复制代码
li+li {border-left: 1px solid #ccc;}

以上 7 种 CSS 选择器的写法均能实现相同效果,本人水平有限,可能还有其他方法。

相关推荐
jiangzhihao05153 小时前
前端自动翻译插件webpack-auto-i18n-plugin的使用
前端·webpack·node.js
软件技术NINI5 小时前
html css网页制作成品——HTML+CSS盐津铺子网页设计(5页)附源码
前端·css·html
Pu_Nine_96 小时前
教程: 在网页中利用原生CSS实现3D旋转动画
css·3d·css3
mapbar_front6 小时前
面试问题—我的问题问完了,你还有什么想问我的吗?
前端·面试
quweiie6 小时前
thinkphp8+layui多图上传,带删除\排序功能
前端·javascript·layui
李鸿耀6 小时前
React 项目 SVG 图标太难管?用这套自动化方案一键搞定!
前端
闲蛋小超人笑嘻嘻6 小时前
树形结构渲染 + 选择(Vue3 + ElementPlus)
前端·javascript·vue.js
叶梅树7 小时前
从零构建A股量化交易工具:基于Qlib的全栈系统指南
前端·后端·算法
巴博尔7 小时前
uniapp的IOS中首次进入,无网络问题
前端·javascript·ios·uni-app
Asthenia04128 小时前
技术复盘:从一次UAT环境CORS故障看配置冗余的危害与最佳实践
前端