1、

*:通用元素选择器

* { margin: 0; padding: 0; }

*选择器是选择页面上的全部元素,上面的代码作用是把全部元素的margin和padding设为0,最基本的清除默认CSS样式方法

*选择器也可以应用到子选择器中,例如下面的代码:

#container * { border: 1px solid black; }

这样ID为container 的所有子标签元素都被选中了,并且设置了border。

2

#ID:ID选择器

#container { width: 960px; margin: auto; }

ID选择器是CSS中效率最高的选择器,使用的时候要保证ID的唯一性。

3

.class:类选择器

.error { color: red; }

类选择器效率低于ID选择器,一个页面可以有多个class,并且class可以放在不同的标签中使用。

4

X Y:标签组合选择器

li a { text-decoration: none; }

标签组合选择器也是常用的选择器。

5

X:标签选择器

a { color: red; } ul { margin-left: 0; }

如果你只是想要页面中的某个标签样式改变,可以选择使用标签选择器。

6

X:visited and X:link

a:link { color: red; } a:visted { color: purple; }

伪类选择器,最常用的为A标签

7

X + Y:毗邻元素选择器

ul + p { color: red; }

毗邻元素选择器,匹配的是所有紧随X元素之后的同级元素Y

8

X > Y:子元素选择器

div#container > ul { border: 1px solid black; }

匹配#container下的所有子元素。

关于X>Y和X Y的区别请看下面的html实例:

<div id="container"> <ul> <li> List Item <ul> <li> Child </li> </ul> </li> <li> List Item </li> <li> List Item </li> <li> List Item </li> </ul> </div>

选择器#container > ul只会匹配到第一个UL,也就是#container的子元素UL,而不是li里面的ul,但是div ul则可以匹配到所有DIV里面的ul。

9

X ~ Y:

ul ~ p { color: red; }

匹配任何在X元素之后的同级P元素。也就是选择了UL之后的同级所有的元素。

10

X[title]:属性选择器

a[title] { color: green; }

匹配具有某属性的标签,例如实例中是匹配具有title属性的a标签。

11

X[href="foo"]

a[href="http://js8.in"] { color: #1f6053; /* nettuts green */ }

也属于属性选择器,匹配属性中为某个值的标签。例如实例中匹配的为href="http://js8.in"的a标签,而其他链接的a标签不选择。

12

X[href*="nettuts"]

a[href*="tuts"] { color: #1f6053; /* nettuts green */ }

属于属性选择器,匹配href中所有含有tuts的标签。正则匹配

13

X[href^="http"]

a[href^="http"] { background: url(path/to/external/icon.png) no-repeat; padding-left: 10px; }

与上面的属相选择标签类似,但是匹配的以http开头的A标签,正则匹配

14

X[href$=".jpg"]

a[href$=".jpg"] { color: red; }

匹配属性中以.jpg结尾的标签,正则匹配,也是属性选择器的一种

15

X[data-*="foo"]

如果你要匹配所有的图片链接,你可以通过下面的CSS来实现:

a[href$=".jpg"], a[href$=".jpeg"], a[href$=".png"], a[href$=".gif"] { color: red; }

但是如果我们给a标签添加一个data-filetype属性,我们就可以使用下面的CSS来快速的选择我们需要匹配的标签了。

<a href="path/to/image.jpg" data-filetype="image"> Image Link </a> </html> <pre lang="css">a[data-filetype="image"] { color: red; }

16

X[foo~="bar"]

a[data-info~="external"] { color: red; }   a[data-info~="image"] { border: 1px solid black; }

匹配属性中具有多个空格分隔的值、其中一个值等于“bar”的X元素,例如下面的例子:

17

X:checked

input[type=radio]:checked { border: 1px solid black; }

这个选择器主要用于checkbox,选择checkbox为当前选中的那个标签。

18

X:after

.clearfix:after { content: ""; display: block; clear: both; visibility: hidden; font-size: 0; height: 0; }   .clearfix { *display: inline-block; _height: 1%; }

before 和after是在选择的标签之前或者之后插入内容,一般用于清除浮动,但是对于IE6、IE7是不可用的。

19

X:hover

div:hover { background: #e3e3e3; }

最常用的就是A标签了,但是在IE6浏览器下除了A标签之外,其他标签div:hover不匹配。

20

X:not(selector)

*:not(p) { color: green; }

选择除了()中选择器之外的标签元素。

21

X::pseudoElement

p::first-line { font-weight: bold; font-size: 1.2em; } p::first-letter { float: left; font-size: 2em; font-weight: bold; font-family: cursive; padding-right: 2px; }

分别用于匹配元素的第一行和第一个字母。看实例:

22

X:nth-child(n)

li:nth-child(3) { color: red; }

匹配X元素中从头数第几个标签,例如上面的代码是匹配的是第三个li标签。

23

X:nth-last-child(n)

li:nth-last-child(2) { color: red; }

与上一个选择器相反,这个选择器是倒序匹配第几个标签,上面的代码的意思是匹配倒数第二个li标签

24

X:nth-of-type(n)

ul:nth-of-type(3) { border: 1px solid black; }

与:nth-child()作用类似,但是仅匹配使用同种标签的元素

25

X:nth-last-of-type(n)

ul:nth-last-of-type(3) { border: 1px solid black; }

与:nth-last-child() 作用类似,但是仅匹配使用同种标签的元素

26

X:first-child

ul li:first-child { border-top: none; }

匹配其父元素的第n个子元素,第一个编号为1

27

X:last-child

ul > li:last-child { color: green; }

匹配其父元素的倒数第n个子元素,第一个编号为1

28

X:only-child

div p:only-child { color: red; }

匹配父元素下仅有的一个子元素,等同于:first-child:last-child或 :nth-child(1):nth-last-child(1)

29

X:only-of-type

li:only-of-type { font-weight: bold; }

匹配父元素下使用同种标签的唯一一个子元素,等同于:first-of-type:last-of-type或 :nth-of-type(1):nth-last-of-type(1)

30

X:first-of-type

li:only-of-type { font-weight: bold; }

匹配父元素下使用同种标签的第一个子元素,等同于:nth-of-type(1)

最新CSS3常用30种选择器总结(适合初学者)的更多相关文章

  1. CSS3常用30种选择器总结

    CSS3常用30种选择器总结 HTML5/CSS3时尚的圆盘时钟动画 带当前日期 www.html5tricks.com/demo/html5-css3-clock-with-date/index.h ...

  2. Mysql常用30种SQL查询语句优化方法

    出处:http://www.antscode.com/article/12deee70111da0c4.html 1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使 ...

  3. MySQL 常用30种SQL查询语句优化方法

    1.应尽量避免在 where 子句中使用!=或<>操作符,否则将引擎放弃使用索引而进行全表扫描. 2.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉 ...

  4. [No000016A]CSS常用三种选择器

    1.HTML Tag p{color:red;} 2.id #myid{color:red;} 3.class .myclass{color:red;} CSS常用文本样式属性 color font- ...

  5. 不可不看!CSS3中三十一种选择器用法

    原文 The 30 CSS Selectors you Must Memorize 由 Jeffrey Way 发表于 2012 年 6 月,介绍了 30 种最常用的 CSS 选择器用法,多加了一种, ...

  6. CSS3常用选择器(一)

    在 CSS 中,选择器是一种模式,用于选择需要添加样式的元素.比如最常用到的#id,.class,标签选择器. 随着CSS3到来,增加了很多新型选择器,这里就常用的做一个总结. 1.属性选择器. 在c ...

  7. 浅谈MySQL中优化sql语句查询常用的30种方法 - 转载

    浅谈MySQL中优化sql语句查询常用的30种方法 1.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where 及 order by 涉及的列上建立索引. 2.应尽量避免在 where 子句中使 ...

  8. CSS3常用属性

    CSS是我们常用的控制网页样式和布局的一种标准. CSS3是最新的CSS标准. CSS3被拆分为"模块",旧的规范也已经拆分为小的块,同时还增加了新的属性. 一些比较重要的CSS3 ...

  9. 史上最全!Selenium元素定位的30种方式

    Selenium对网页的控制是基于各种前端元素的,在使用过程中,对于元素的定位是基础,只有准去抓取到对应元素才能进行后续的自动化控制,我在这里将对各种元素定位方式进行总结归纳一下. 这里将统一使用百度 ...

随机推荐

  1. Python进阶08 异常处理

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 本文特别感谢kylinfish的纠正,相关讨论见留言区. 异常处理 在项目开发中, ...

  2. Good Sentences

    Wine in, truth out One is never too old to learn What is done can not be undone Time tries all thing ...

  3. Servlet中的请求转发和重定向

    跳转和重定向 有的时候客户端请求到达服务端后需要对请求重新转发到其它Servlet甚至别的服务器,这就需要跳转和重定向. 区别 一般来说,跳转是服务器内部跳转,例如将请求从一个Servlet转发给另外 ...

  4. [kuangbin带你飞]专题十一 网络流

            ID Origin Title   34 / 81 Problem A POJ 3436 ACM Computer Factory   92 / 195 Problem B POJ 3 ...

  5. (easy)LeetCode 204.Count Primes

    Description: Count the number of prime numbers less than a non-negative number, n. Credits:Special t ...

  6. Winista.Text.HtmlParser; 获取html

    using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using Sy ...

  7. Longest Increasing Subsequence(DP)

    public static int LIS(List<Integer> al) { int[] arr = new int[al.size()]; int lis = 0; arr[0] ...

  8. @SessionAttributes与HttpSession

    SessionAttributes注解将model中与它同名的属性保存在HttpSession中. 在controller的方法执行完毕后处理SessionAttributes注解并保存的,是Hand ...

  9. FPGA一个博客学习

    FPGA一个博客学习 http://bbs.ednchina.com/BLOG_PERSONALCAT_100185_2001619.HTM

  10. html5—— 应用程序缓存

    使用 HTML5,通过创建 cache manifest 文件,可以轻松地创建 web 应用的离线版本. 什么是应用程序缓存(Application Cache)? HTML5 引入了应用程序缓存,这 ...