- Java锁的逻辑(结合对象头和ObjectMonitor)
- 还在用饼状图?来瞧瞧这些炫酷的百分比可视化新图形(附代码实现)⛵
- 自动注册实体类到EntityFrameworkCore上下文,并适配ABP及ABPVNext
- 基于Sklearn机器学习代码实战
你知道的和你不知道的所有选择器。不包含尚未广泛实现的,也不包含已弃用的.
直接用标签匹配特定的元素 。
span {
...
}
p {
...
}
以 . 开头,匹配含有这个 class 的元素 。
.info {
...
}
p.info { /* 匹配含有 info 类的 p 元素 */
...
}
.info.log { /* 匹配同时含有 info 和 log 类的元素 */
...
}
以 # 开头,匹配对应 id 的元素.
#info {
...
}
p#info {
...
}
除了 id 和 class,也可以筛选其他参数进行匹配,并且除了全字匹配还提供了多重手段.
/* 存在 title 的 <a> 元素 */
a[title]
/* 存在 href 属性并且值为"https://example.org"*/
a[href="https://example.org"]
/* 存在 href 属性并且内容包含"example"*/
a[href*="example"]
/* 存在 href 属性并且以".org"结尾 */
a[href$=".org"]
/* 存在 href 属性并且以"https"开头 */
a[href^="https"]
/* class 用空格分割的列表中存在 logo。效果等于.logo。用于class这样空格分隔的属性 */
a[class~="logo"]
/* 存在 lang 属性并且以"zh"或"zh-"开头。用于匹配lang属性*/
div[lang|="zh"]
/* i 表示忽略大小写 */
a[href="https://example.org" i]
* 表示通配符,可以匹配任何元素。性能较低,谨慎使用.
组合选择器可以连接多个元素.
子选择器用 > 表示,匹配第一个元素的直接后代的第二个元素(即 child)。后代选择器只需要用空格隔开,不要求是直接后代(即 descendant).
p span{ /* 所有 p 元素中的 span 元素 */
color:red;
}
p > span{ /* 所有 p 元素中的直接子元素 span 元素 */
color:blue;
}
<p>
<span>p span和p>span都匹配</span>
<p>
<span>只匹配p span</span>
</p>
</p>
注意 :p.info 和 p .info 是不一样的.
与上文类似,兄弟选择器用 + 表示,匹配第一个元素直接相邻之后的第二个元素。相邻兄弟选择器用 ~ 表示,只要求是兄弟(同一个父元素),不要求相邻.
img + p /* 紧跟在img后面的p */
img ~ p /* 和img有相同父元素的p */
<p>
<img/>
<p>匹配 img+p 和 img~p</p>
<p>只匹配 img~p</p>
</p>
选择器列表用逗号 , 表示,用逗号连接的选择器共同使用规则.
span, div{}
span, .info{}
注意 :1. p span, .info 会匹配 p span 和 .info,而不是 p span 和 p .info,实现后者需要:is 2. 逗号选择器是阻塞的,如果其中一个标签不合法,整个规则都不会生效 。
CSS 伪类是添加到选择器的一种关键字,表示这个元素的特殊状态。例如,伪类 :hover 可以用于选择一个按钮,当用户的指针悬停在按钮上时,设置此按钮的样式。但这个类并不真的在 class 中,所以叫伪类。伪类用 : 表示.
常用:
:link
表示未访问的链接,匹配尚未访问的链接,默认一般是蓝色。 :visited
表示访问过的链接,一般是紫色。出于隐私限制,这个伪类用的越来越少。 :hover
表示鼠标移向元素时的情况 :active
表示鼠标正在点击元素的情况
.info:link{
color: blue;
}
.info:hover{
color: red;
}
.info:active{
color: purple;
}
<a href="example">a link</a>
注意 : 1. 有 href 属性的 a 标签才是链接,没有的不算。:link 也不只有 a 标签,其他标签的链接也可以(比如 link 标签)。 2. LVHA 规则:定义同一个链接多种情况的样式时,要按 link visited hover active 的顺序。这是因为他们的优先级相同,如果后出现的覆盖先出现的就会出现问题,比如将 hover 放到 active 后,那点击链接时两个伪类都满足,hover 会覆盖 active 导致 active 的设置不生效.
:any-link
表示未访问的和已访问的链接,包括 link 和 visited。 :checked
表示正选中的单选框(radio),复选框(checkbox)和下拉菜单项(option)元素 :default
表示单选框,复选框和下拉菜单项中默认的那个元素 :disabled
表示被禁用的元素 :enabled
表示被启用的元素 :focus
表示获得焦点的元素 :focus-within
表示获得焦点或者后代获得焦点的元素 :focus-visible
表示获得焦点且焦点可见的元素。这是什么意思呢?
<button> A </button>
<button> B </button>
<style>
button:focus{ background-color: red;} /* tab 过去也生效 */
/*button:focus-visible{ background-color: green;*/}</style>
我们设定 :focus,显然是给鼠标按下去准备的,却忘了键盘 tab 获得焦点的情况。对于 button,用鼠标点击的时候,你知道自己在点哪,就不算 :focus-visible;而用 tab 切换或者 js 跳转时,你需要不一样的焦点提醒,此时 :focus-visible 生效,这样就可以区分二者。对于输入框来说,所有聚焦都触发 :focus-visible。取消掉注释,两种focus样式就不再相同了.
其实浏览器的默认样式就考虑到了,默认按钮点击时会变深,tab 时则是加上一圈 outline。自己的样式会让默认样式失效,如果需要精细的设计,就可以使用 :focus-visible。 一个案例 。
:in-range
表示值在min到max范围内的输入框 :out-of-range
表示值不在min到max范围内的输入框 :indeterminate
表示“不确定”的表单元素,包括设置了 indeterminate 的选框,尚未选择的单选框,尚未完成的进度条。 :valid
表示输入合法的输入框 :invalid
表示输入不合法的输入框 :required
表示设置必填的输入 :optional
表示设置不是必填的输入 :placeholder-shown
表示拥有 placeholder 的输入框 :read-only
表示设置了只读属性的输入 :read-write
表示可修改的输入 :autofill
表示按下浏览器自动填充功能的输入框 :empty
表示没有子元素的元素(文本节点也算元素,注释不算)。比如 <p>assa</p>
并不能匹配, <p></p>
才可以。 :first-child
表示“是父元素的第一个子节点”。 :last-child
表示“是父元素的最后一个子节点”。 :first-of-type
表示“是父元素的第一个对应元素的子节点”。 :last-of-type
表示“是父元素的最后一个对应元素的子节点”。
<p>
<span>p :first-child 或者 span:first-child</span>
<a>p a:first-of-type</a>
<a></a>
</p>
:nth-child
后接整数或一次函数,选中特性序号的孩子节点。
p :nth-child(2) /* 第二个孩子 */
p :nth-child(2n) /* 第2,4,6……个元素,n从0开始 */
p :nth-child(2n+1) /* 第1,3,5……个元素 */
p :nth-child(4n+3) /* 第4,7,10……个元素 */
p :nth-child(-n+3) /* 第3,2,1个元素 */
:nth-last-child
同上,不过是倒着数 :nth-of-type
同上,也就是 :first-child
和 :first-of-type
的区别,限定了元素 :nth-last-of-type
同上。 :only-child
表示没有其他兄弟的元素 :only-of-type
表示没有其他相同元素兄弟的元素 :has
表示“拥有……”的,它的参数是一个逗号选择器列表。注意不能 has 嵌套。Firefox 暂不支持
p:has(span, .info) /* 含有 span或.info的 p */
h1:has(+h2) /* 满足h1+h2的 h1 */
:is
和 :where
后接选择器列表,表示多选一。他们的区别是 is 计算优先级,而 where 不计入。 p :is(span, .info)
表示p span 和 p .info :not
后接选择器列表,和 is 相反,表示排除这些选项,选中不是这些元素的元素。 :root
在 HTML 文档中,:root 就等于 <html>
元素 :modal
表示“模态”,即 js 用 showModal 构造的阻塞对话框的样式。 一个案例 :lang
用于选中元素的语言属性 :target
表示当前锚点代表的元素。比如当前 url 是 example.org#title
,那么 id 为 title 的元素就会被匹配 :defined
表示所有的默认标签(div span)和用 js customElements.define
定义的自定标签,有了这个伪类,就可以把自定标签定义之前和之后区分 :host
匹配所有 shadow root 的根元素,也可以加上括号, :host()
后接选择器,表示符合条件的根元素。 :host-context
后接选择器,匹配在 shadow DOM 中符合条件的元素。 伪元素是一个附加至选择器末的关键词,允许你对被选择元素的特定部分修改样式。但这个部分在 dom 中并不存在,所以叫做伪元素。用 :: 表示,但像伪类一样只打一个冒号也可以.
::after
在已选中元素之后再构造一个元素 ::before
在已选中元素之前再构造一个元素 ::first-letter
匹配本元素第一个字符 ::first-line
匹配本元素第一个行 ::marker
匹配一个 list 的元素的 marker,比如列表前面的数字序号和小圆点。 ::placeholder
匹配输入框的 placeholder 文本 ::selection
表示元素中被用户框选的部分 ::part
后接字符串,匹配 shadow tree 中满足part条件的元素 ::file-selector-button
代表一个文件提交按钮 ::cue
匹配这个元素的 WebVTT 提示 ::slotted
匹配模板中的插槽元素 ::target-text
匹配当前的文本锚点所在的文本。 最后此篇关于CSS3所有的选择器整理(2023.2)的文章就讲到这里了,如果你想了解更多关于CSS3所有的选择器整理(2023.2)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
当我创建一个数据库时,我被要求选择默认排序规则,当我创建一个表时,我被要求选择排序规则。 utf8_general_ci 或...拉丁...?区分哪个是对的依据是什么? 最佳答案 A collatio
PHP不会检查单引号 '' 字符串中变量内插或(几乎)任何转义序列,所以采用单引号这种方式来定义字符串相当简单快捷。但是,双引号 "" 则不然,php会检查字符串中的变量或者转义
正则(regular),要使用正则表达式需要导入Python中的re(regular正则的缩写)模块。正则表达式是对字符串的处理,我们知道,字符串中有时候包含很多我们想要提取的信息,掌握这些处理字符
在开发过程中,有时需要对用户输入的类型做判断,最常见是在注册页面即用户名和密码,代码整理如下: 只能为中文 ?
]js正则表达式基本语法(精粹): http://www.zzvips.com/article/94068.html 许多语言,包括P
1、首先安装mongodb 1.下载地址:http://www.mongodb.org/downloads 2.解压缩到自己想要安装的目录,比如d:\mongodb 3.创建文件夹d:\mo
我更愿意在 R 中执行以下操作,但我愿意接受(易于学习的)其他解决方案。 我有多个(比如说 99 个)制表符分隔文件(我们称它们为 S1.txt 到 S99.txt)和表格,所有文件都具有完全相同的格
我制作了一个小程序,可以使用数学进行物理计算。 我有几个 if 语句,它们做同样的事情,但变量不同,但它们必须是它们,就好像 TextBox 是空的,int 将是 0。 例子如下: if (first
我正在构建需要扩展框的东西 - 这很好,我可以正常工作。然而,如果你看看这个FIDDLE你会看到它有点乱。我希望有一种方法可以扩展它们所在的盒子,这样它们就不会跳来跳去?那么盒子 3 的左侧会比右侧膨
我相当确定(在 MATLAB 中)应该有一个优雅的解决方案,但我现在想不起来。 我有一个包含 [classIndex, start, end] 的列表,我想将连续的类索引折叠成一个组,如下所示: 这个
维基百科将 XMPP 定义为: ...an open-standard communications protocol for message-oriented middleware based on
我的代码库已经进入了某种状态,希望能够摆脱它 repo 看起来有点像这样(A1、B1、C1 等显然是提交) A1 ---- A2 ---- A3 ---- A4 -
如何整理以下数据框 data.frame(a = c(1,2), values = c("[1.1, 1.2, 1.3]", "[2.1, 2.2]")) a values 1
所以我试图在 Haskell 中生成出租车号码列表。出租车号码是可以用两种不同方式写成两个不同立方体之和的数字 - 最小的是 1729 = 1^3 + 12^3 = 9^3 + 10^3 . 现在,我
我正在使用 roxygen2 来记录我正在开发的包的数据集。我知道你可以 use roxygen to document a dataset ,但是Shane's answer最终建议进行黑客攻击,虽
这个问题在这里已经有了答案: How can I combine two strings together in PHP? (19 个回答) 关闭 5 年前。 提前致歉,尽管我已经尝试并失败了几件不
我有一个大部分整洁的数据框,但有 2 列包含基准,而不是将基准合并为观察结果。我该如何整理,以便将“Facility_score”和“TTP”col_names 添加为每个独特的 FYQ 和 Metr
我有以下输入数据。每一行都是一个实验的结果: instance algo profit time x A 10 0.5 y A
我已经使用 PHP 和 MySQL 实现了搜索。目前我的表格整理是 "utf8_unicode_ci"。问题是,使用此排序规则 "ä"= "a" 是。如果我将排序规则更改为 "utf_bin" 一切正
所以我是 JS 和 Jquery 库的新手。我一直在玩弄一些东西,可以看到它非常不整洁,这就是我希望你们能帮助建议一种更好的方法来实现我想要实现的目标的地方。 目标: 要有多个复选框,其中一些如果被选
我是一名优秀的程序员,十分优秀!