CSS - 选择器的学习和排雷

  1. 首先列举各种选择器, 之后描述作用以及个人认为有坑的地方
  2. 叫法这个东西并不是唯一的, 自己能记住和理解怎么回事就行,一个名字而已
  3. E,F并不单单指元素, 也可以是类,或ID
  4. 描述如果不形容的不够通俗, 下面会有大白话, 有图有XX
  5. 我不是专业前端但是对前端感兴趣, 有不对的地方欢迎指正

(一) 元素选择器

元素选择器 含义
E 标签选择器
E#id ID选择器
E.class 类选择器
* 通配选择器

(二) 关系选择器

关系选择器 | 名称 | 描述
--- |---
E F | 选中E元素的所有后代元素
E,F | 同时选中E元素和F元素
E>F | 只选中第一代后代元素(只有儿子可以, 孙子不行)
E+F | 只选中E元素同级的下一个元素
E~F | 只选中E后面的F元素


(三) 属性选择器

属性选择器 描述
E[attr] 选择有属性attr的E元素
E[attr='val'] 选择有attr属性值为val的E元素
E[attr^='val'] 选择attr属性值以val开头的E元素
E[attr$='val'] 选择attr属性值以val结尾的E元素
E[attr*='val'] 选择attr属性值里含有val的E元素
E[attr~='val'] 选择attr属性值里有val的E元素, val必须是完整单词
E[attr ='val'] 选择attr属性以val开头的E元素, val必须是完整单词

(四) 伪类选择器

伪类选择器 描述
a:link 选择未被访问的链接
a:visited 选择已被访问过的链接
a:active 选择活动时的链接(鼠标按下到释放之间的时候)
a:hover 选择鼠标放上去的时候的链接

以上四种伪类选择器目前只知道适用于a标签

伪类选择器 描述
E:focus 选择获取焦点的E元素
E:first-letter 选择E元素里的首字母(汉字的话就是第一个汉字)
E:first-line 选择E元素的第一行
E:before E元素内部的最前面插入内容并设置样式
E:after E元素的内部的最后面插入内容并设置样式
E:lang(val) 选择lang属性以val开头的E元素
E:first-child 选择是其父元素的第一个子元素的E元素
E:last-child 选择是其父元素的最后一个子元素的E元素
E:nth-child(N) 选择是其父元素的第N个子元素的E元素
E:nth-last-child(N) 选择是其父元素的倒数第N个子元素E元素
E:only-child 选择是其父元素唯一的子元素的E元素
E:first-of-type 选择是其父元素的子元素里第一个E元素的E元素
E:last-of-type 选择是其父元素的子元素里最后一个E元素的E元素
E:nth-of-type(N) 选择是其父元素的子元素里的第N个E元素的E元素
E:nth-last-of-type(N) 选择是其父元素的子元素里的倒数第N个E元素的E元素
:root 选择文档的根元素
:empty 选择没有子元素的
:target 选择当前活动的元素
:enabled 选择启用的表单元素
:disabled 选择禁用的表单元素
:checked 选择被选中的表单元素
:not(selector) 选择不是selector的元素
::selection 选择鼠标选取的时候的元素

以下说一下个人觉得在使用可能有坑的地方

  1. 注意E FE>F的区别:
  • E F: 只要F是E的后代元素(无论第几代)都被选中
  • E>F: F必须是E的第一代子元素, 也就是说, 只有儿子会被选中, 孙子都不好使!
  1. E+F会只选择E元素后面的第一个F元素(这个没什么好说的, 不过W3C给的释 义是E后面的所有F元素, 这是不正确的, 下面上图)

    注意p2并没有红色的边框
  2. E~F:选中E后面的同级元素F

  • 在li元素前面的p标签并没有被选中

  • li的子元素p标签也没有被选中

  • p1, p2, p3都被选中了, 说明只要在E之后的F元素就会被选中, 间隔其它的元素也无所谓

    E~F
  1. :focus: 很遗憾, 目前这个属性在Mac OS X系统上的Chrome浏览器和Safari浏览器里效果并不是很好, Mac OS X系统上, 当input元素获取焦点的时候,系统会自动给一层蓝色的框, 影响了我们要的效果

  2. :first-letter: 第一个字母会被选中

  • 如果是汉字的话, 第一个汉字会被选中


    第一个字母被选中
  • 如果句子如: I'm the first line! 这样, I后面的分号'也会被选中
    分号也被选中
  1. :first-line: 选中第一行

    first-line

  2. :before: 在元素内部的前面插入(:after同理)

    注意控制台里的结构

  3. :nth-child(N): 是其父元素的第N个子元素, 注意这里的N从1开始数!

    nth-child

  4. :only-child: 其父元素的唯一子元素, 也就是说, 选中的这个元素, 它的父元素必须只能有选中的这个元素这个唯一的一个字元素, 不能再有其它子元素, 就是它的父元素不能有二胎! 它就是独苗!

    没有二胎的

  5. :nth-of-child(N): 这个没什么好说的, 和:nth-child(N)类似, 注意 N也是从第一个开始数, 也就是说, 想选择第一个就写成: :nth-of-child(1)

  6. :root: 选择文档的根元素, 实际就是html标签

  7. :empty: 选择没有子元素的,这个有几个地方需要注意一下

  • 空格是不可有的
  • 换行也是不可以有的


    原效果

    有空格

    有换行
  1. :target: 选择当前活动的元素, 这个选中的对象相当于a标签的锚点,只有点击了链接以后, 这个属性就被激活了, 然后CSS效果才会有效. 另外就是, 刷新页面也是没用的, 这个链接你访问过, 刷新以后仍然处于激活状态, 所以样式依然有效
![未激活的锚点](http://upload-images.jianshu.io/upload_images/1818988-a1fcf71e7f1426c7.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)
激活状态的, 刷新仍处于有效状态
  1. ::selection: 选择鼠标选取的时候的元素
> 就相当于鼠标选择的时候, 比如要复制某些网页上的文字的时候
> 另外就是这个必须以两个冒号开头, 否则无效.

(完)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,793评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,567评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,342评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,825评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,814评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,680评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,033评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,687评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,175评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,668评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,775评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,419评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,020评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,978评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,206评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,092评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,510评论 2 343

推荐阅读更多精彩内容

  • 选择器 元素选择符 关系选择符 属性选择符 伪类选择符 伪对象选择符 一、元素选择符 通配选择符 (*):选择所有...
    云外之境阅读 1,847评论 0 0
  • 1.class 和 id 的使用场景? 类选择器允许以一种独立于文档元素的方式来指定样式。该选择器可以单独使用,也...
    草鞋弟阅读 2,402评论 0 1
  • 基本选择器 *{} 通配符选择器,适用任何元素h1 标签选择器,选择h1标签内元素....
    字母31阅读 612评论 0 0
  • 1.class 和 id 的使用场景? 当页面中某元素的样式并不独有,或与其他元素共用一个样式时,可以为该元素指定...
    Feiyu_有猫病阅读 905评论 0 0
  • CSS选择器结构逻辑图 接下来按照结构逻辑图具体讲解各个选择器的作用及用法; 基本选择器 基本选择器主要有以下5类...
    FoolishFlyFox阅读 555评论 0 8