我对CSS选择器的认识
我对CSS选择器的认识
一、简述
CSS选择器是对HTML元素进行选择的筛选条件,大概可以分为两类:
- 特征选择器——根据元素自身所具有的某种特征进行筛选,比如名称、ID、属性等;
- 关系选择器——根据元素与其他元素的关系进行筛选,比如子元素、兄弟元素等;
在真正使用的时候,几个简单的选择器可以组合成更复杂的选择器,所以谁也说不上CSS选择器有多少。还有两个选择器是功能性的,它们可以给元素已有内容之前或之后添加新内容。
我做了一个项目,里面包含一个测试CSS选择器的小功能,请看这里。
二、归纳
下文中所有的 SELECTOR 都代表任何一个有效的选择器。
1. 特征选择器:
| 描述 | 选择器 | 备注 |
| 1. 无论有什么特征——即全部 | * { } | |
| 2. 元素名称是 "element" | element { } | |
| 3. 具有类名 "className" | .className { } | |
| 4. 具有id名 "someID" | #someID { } | |
| 5. 带有属性 attr | SELECTOR[attr] { } | |
| 6. 带有属性 attr,且属性值为 "value" | SELECTOR[attr="value"] { } | |
| 7. 带有属性 attr,且其若干个属性值中有一个是 "value" | SELECTOR[attr~="value"] { } | |
| 8. 带有属性 attr,且其属性值包含字符串 "str" | SELECTOR[attr*="str"] { } | |
| 9. 鼠标正位于其上方 | SELECTOR:hover { } | |
| 10. SELECTOR 是个独生子——它的父元素只有它这一个子元素 | SELECTOR:only-child { } | |
| 11. SELECTOR 是其父亲的第一个子元素 | selector:first-child { } | |
| 12. SELECTOR 是其父亲的第 N 个子元素 | selector:nth-child(N) { } | |
| 13. SELECTOR 是其父亲的最后一个子元素 | selector:last-child { } | |
| 14. SELECTOR 内部是真空——连空格都没有 | SELECTOR:empty { } | |
| 15. SELECTOR 被某个链接锚定了,而且该链接被点击了 | SELECTOR:target { } | <a href="#topic">跳转到 SELECTOR 处</a> |
| 16. SELECTOR 中被用户通过鼠标拖动选中的内容 | SELECTOR::selection { } | |
| 链接专有的特征 | ||
| 17. 未被访问的链接 | a:link { } | |
| 18. 已被访问的链接 | a:visited { } | |
| 19. 正在被点击的链接 | a:active { } | |
| 表格元素专有的特征 | ||
| 20. 目标是启用的 | SELECTOR:enabled { } | |
| 21. 目标是禁用的 | SELECTOR:disabled { } | |
| 22. 目标是被选中的(单选框、复选框) | SELECTOR:checked { } | |
| 23. 目标获得了焦点 | SELECTOR:focus { } | 能接收用户输入的元素,当它正在接收时,就获得了焦点。 |
| 两个功能性选择器 | ||
| 24. 给 SELECTOR 的内容之前加上些东西 | SELECTOR:before { } | |
| 25. 给 SELECTOR 内容之后加上些东西 | SELECTOR:after { } | |
2. 关系选择器
| 描述 | 选择器 | 备注 |
| 1. SELECTOR1 和 SELECTOR2 | SELECTOR1, SELECTOR2 { } | |
| 2. 位于 SELECTOR1 之后的所有兄弟元素 SELECTOR2 | SELECTOR1~SELECTOR2 { } | |
| 3. 与 SELECTOR1 紧邻着的 SELECTOR2 元素 | selector1+selector2 { } | |
| 4. SELECTOR 的首字母 | selector:first-letter { } | 类似的还有 SELECTOR:first-line { } |
| 5. SELECTOR1 的所有子元素 SELECTOR2 | selector1>selector2 { } | |
| 6. SELECTOR1 的所有后代元素 SELECTOR2 | selector1 selector2 { } | |
| 7. 所有不是 SELECTOR2 的 SELECTOR1 | SELECTOR1:not(SELECTOR2) { } |
个人浅薄之见,肯定有不到之处,希望得到有心之人指正,谢谢!
我对CSS选择器的认识的更多相关文章
- 前端极易被误导的css选择器权重计算及css内联样式的妙用技巧
记得大学时候,专业课的网页设计书籍里面讲过css选择器权重的计算:id是100,class是10,html标签是5等等,然后全部加起来的和进行比较... 我只想说:真是误人子弟,害人不浅! 最近,在前 ...
- css选择器
常用css选择器,希望对大家有所帮助,不喜勿喷. 1.*:通用选择器 * { margin: 0; padding: 0; } 选择页面上的全部元素,通常用于清除浏览器默认样式,不推荐使用. 2.#i ...
- dynamic-css 动态 CSS 库,使得你可以借助 MVVM 模式动态生成和更新 css,从 js 事件和 css 选择器的苦海中脱离出来
dynamic-css 使得你可以借助 MVVM 模式动态生成和更新 css,从而将本插件到来之前,打散.嵌套在 js 中的修改样式的代码剥离出来.比如你要做元素跟随鼠标移动,或者根据滚动条位置的变化 ...
- CSS选择器的权重与优先规则?
我们做项目的时候,经常遇到样式层叠问题,被其他的样式覆盖,或者写的权重不高没效果,对权重没有具体的分析,做了一个总结. css继承是从一个元素向其后代元素传递属性值所采用的机制.确定应当向一个元素应用 ...
- css选择器的使用详解
-.css选择器的分类: 二.常用选择器详解: 1.标签选择器: 语法: 标签名 { 属性:属性值; } 代码示例: h1 { color: #ccc; font-size: 28px; } 2.类选 ...
- js,jq,css选择器
js获取节点: var chils= s.childNodes; //得到s的全部子节点 var par=s.parentNode; //得到s的父节点 var ns=s.nextSbiling; / ...
- CSS系列:CSS选择器
选择器(selector)是CSS中很重要的概念,所有HTML语言中的标记样式都是通过不同的CSS选择器来控制的.用户只需要通过选择对不同的HTML标签进行选择,并赋予各种样式声明,即可实现各种效果. ...
- 细说CSS选择器
众所周知,CSS的一个核心特征就是能向文档中的一组元素类型应用某些规则.每个规则都有两个基本部分:选择器(selector)和声明块(declaration block).下图显示了规则的各个部分. ...
- CSS选择器 转
来自于:http://www.cnblogs.com/webblog/archive/2009/08/07/1541005.html 最近在研究jQuery的选择器,大家知道jQuery的选择器和cs ...
- HTML5 -入门 (---css样式-------------(css基础与css选择器)---------------------—)
---恢复内容开始--- 一css基础入门与css选择器 CSS英文全拼:cascading style sheet 层叠样式表. 在html中使用:要在head中写style标签,所有样式放在sty ...
随机推荐
- 洛谷P2235 [HNOI2002]Kathy函数
传送门 题解 // luogu-judger-enable-o2 //minamoto #include<cstdio> #include<cstring> using nam ...
- HTML5应用——生日快乐动画之星星
在讲述绘制星星动画之前,先介绍一点javascript知识. 面向对象: javascript本质上不是面向对象语言,而是脚本语言,一般只适合简单.代码量少的程序,因为脚本过于复杂会直接导致浏览器出现 ...
- Python发送邮件代码
Python发送带附件的邮件代码 #coding: utf-8 import smtplib import sys import datetime from email.mime.text impor ...
- Bridge Across Islands POJ - 3608 旋转卡壳求凸包最近距离
\(\color{#0066ff}{题目描述}\) 几千年前,有一个小王国位于太平洋的中部.王国的领土由两个分离的岛屿组成.由于洋流的冲击,两个岛屿的形状都变成了凸多边形.王国的国王想建立一座桥来连接 ...
- jdk 1.6.0_41 下载
Java SE Development Kit 6u41 Product / File Description File Size Download password Linux x86 65.43 ...
- boost库checked_delete的使用
在查看boost库时发现一个小文件checked_delete.hpp里面几个小函数,它的作用用很简短的话来说:防止未定义的行为造成delete时的内存泄露.实现如下: template<cla ...
- OpenCV&Qt学习之四——OpenCV 实现人脸检测与相关知识整理
开发配置 OpenCV的例程中已经带有了人脸检测的例程,位置在:OpenCV\samples\facedetect.cpp文件,OpenCV的安装与这个例子的测试可以参考我之前的博文Linux 下编译 ...
- MySQL使用总结
本篇博客,主要是对MySQL使用的一些总结,会持续更新. MySQL下载安装不再赘述.去官网即可.有企业版和社区版. 用命令行的方式: 1. 先运行MySQL目录的bin下的mysqld.exe ...
- Qt 学习之路 2(23):自定义事件
Qt 学习之路 2(23):自定义事件 豆子 2012年10月23日 Qt 学习之路 2 21条评论 尽管 Qt 已经提供了很多事件,但对于更加千变万化的需求来说,有限的事件都是不够的.例如, ...
- google ---gson字符串数组用GSON解析然后用逗号隔开拼接,去掉最后一个逗号
public static void main(String[] args) { String ss= "[{\"type\":\"0\",\&quo ...