有哪些选择器 基本选择器
通配选择器(*)
ID选择器(#ID)
类选择器(.className)
元素选择器(tagName)
后代选择器(a b)
子元素选择器(a>b)
相邻后面兄弟元素选择器(a + b)
通用后面兄弟选择器(a 〜 b)
群组选择器(selector1,selector2,...)
这里面平时不太常用的选择器有相邻后面兄弟选择器和通用后面兄弟选择器
首先,很多资料上把它们叫做相邻兄弟选择器和通用兄弟选择器,我觉得这样会有一定的误导意义,
例如:
`
</>复制代码
-
- 1
-
- 2
-
- 3
-
- 4
-
- 5
-
- 6
-
- 7
-
- 8
-
- 9
li {
list-style: none;
height: 20px;
width: 20px;
background: red;
margin: 10px;
border-radius: 10px;
text-align: center;
color: white;
float: left;
line-height: 20px;
}
`
当使用相邻兄弟选择器时:
</>复制代码
.l3 + li {
background: green;
}
效果为:
可以看出相邻兄弟选择器只会选择它后面的一个兄弟元素。
当使用通用兄弟选择器:
</>复制代码
.l3 ~ li {
background: green;
}
效果为:
可以看出来通用兄弟选择器会选择它后面所有的兄弟元素
属性选择器E[attr]:只使用属性名,但没有确定任何属性值
E[attr="value"]:指定属性名,并指定了该属性的属性值
E[attr~="value"]:指定属性名,并且具有属性值,此属性值是一个词列表,并且以空格隔开,其中词列表中包含了一个value词,而且等号前面的“〜”不能不写
E[attr^="value"]:指定了属性名,并且有属性值,属性值是以value开头的;
E[attr$="value"]:指定了属性名,并且有属性值,而且属性值是以value结束的;
E[attr*="value"]:指定了属性名,并且有属性值,而且属值中包含了value;
E[attr|="value"]:指定了属性名,并且属性值是value或者以“value-”开头的值(比如说big-name);
属性选择器中有波浪(〜)时属性值有value时就相匹配,没有波浪(〜)时属性值要完全是value时才匹配
伪类选择器动态伪类
在链接中常看到的锚点伪类:link、visited、hover、active
UI元素状态伪类
例如 :enabled,:disabled,:checked等,这些主要是对一些表单元素操作。
比较常见的如"type="text"有enable和disabled两种状态,前者为可写状态后者为不可写状态。
first-child: 选择某个元素的第一次的出现
last-child: 选择某个元素的最后一次的出现
nth-child(): 选择某个元素的一个或多个特定的条件的出现
权重如何计算根据样式所在位置,对元素的影响也有关系:内联样式(标签内style形式) > style标签 > link标签
根据选择器的类型,id选择器 > 类、属性选择器和伪类选择器 > 元素和伪元素
一般来说我们的计算方式为,从0开始,一个行内样式+1000,一个id+100,一个属性选择器/class或者伪类+10,一个元素名,或者伪元素+1
参考资料:
你应该知道的一些事情-css权重
css选择器-基本选择器
css选择器-属性选择器
css选择器-伪类选择器
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/115832.html
有哪些选择器 基本选择器 通配选择器(*) ID选择器(#ID) 类选择器(.className) 元素选择器(tagName) 后代选择器(a b) 子元素选择器(a>b) 相邻后面兄弟元素选择器(a + b) 通用后面兄弟选择器(a 〜 b) 群组选择器(selector1,selector2,...) 这里面平时不太常用的选择器有相邻后面兄弟选择器和通用后面兄弟选择器首先,很多资料上把它...
摘要:字囊括上百个前端面试题的项目开源了这个项目是什么项目内容这个项目目前在上刚刚开源主要内容如下前端面试题主要整理了高频且有一定难度的前端面试题对这些面试题进行解读前端原理详解针对一些有一定难度面试题涉及的知识点进行详解比如涉及的编译原理响应式 20W字囊括上百个前端面试题的项目开源了 这个项目是什么? 项目内容 这个项目目前在GitHub上刚刚开源,主要内容如下: 前端面试题: 主要整...
摘要:我们基本上都会从以下步骤入手,这些也是绝大多数运维工程师在定位故障时前几分钟的主要排查点一尽可能搞清楚问题的前因后果不要一下子就扎到服务器前面,你需要先搞明白对这台服务器有多少已知的情况,还有故障的具体情况。 遇到服务器故障,问题出现的原因很少可以一下就想到。我们基本上都会从以下步骤入手,这些也是绝大多数运维工程师在定位故障时前几分钟的主要排查点:一、尽可能搞清楚问题的前因后果不要一下子就扎...
摘要:三个元素会从左往右占据父元素的空间这很显然。左右侧边栏的宽度都是,中间元素的宽度将会占据元素的剩余宽度。同样会导致父元素有部分剩余空间没有分配。 自从开始开学习 CSS 布局,想要比较灵活的把父元素的空间分配给各个子元一直是各个前端程序员的梦想。在 flex 之前,如果不是专门去搜索相关的解决方案,一般人几乎想不出非常灵活的三(多)栏等高布局方案,而即使看了解决方案,很多人也会大呼奇技...
摘要:既然出现了,那怎么办,目前并没听说出现什么新的技术替代它虽然它真的已经很不适合现代的前端了,那么只能开发一个新的引擎提高性能,这就是火狐家的量子引擎又叫。这就是所谓的,火狐前一个引擎所做的那样。 开始 本文翻译自Inside a super fast CSS engine: Quantum CSS ,如果想要阅读原文,可以点击前往,以下内容夹杂本人一些思考,翻译也并不一定完全。 碎碎念...
阅读 2543·2023-04-26 00:57
阅读 916·2021-11-25 09:43
阅读 2224·2021-11-11 16:55
阅读 2215·2019-08-30 15:53
阅读 3598·2019-08-30 15:52
阅读 1462·2019-08-30 14:10
阅读 3381·2019-08-30 13:22
阅读 1213·2019-08-29 11:18
极致性价比!云服务器续费无忧!
Tesla A100/A800、Tesla V100S等多种GPU云主机特惠2折起,不限台数,续费同价。
NVIDIA RTX 40系,高性价比推理显卡,满足AI应用场景需要。
乌兰察布+上海青浦,满足东推西训AI场景需要