7种不同的选择器

选择器


要想将CSS样式应用于特定的HTML元素,首先需要找到该目标元素。在CSS中,执行这一任务的样式规则部分被称为选择器(选择符)。

标签选择器(元素选择器)


标签选择器是指HTML标签名称作为选择器,按标签名称分类,为页面中某一类标签指定统一的CSS样式。其基本语法格式如下:

[^footnote]
标签名{     属性:属性值1;属性2:属性值2;属性3:属性值3;}    
​
或者
​
元素名{     属性:属性值1;属性2:属性值2;属性3:属性值3;}

 

标签选择器最大的优点是能快速为页面中同类型的标签统一样式,同时这也是它的缺点,不能设计差异化的样式。

类选择器


类选择器使用“.”(英文点号)进行标识,后面紧跟类名,其基本语法格式如下:

[^footnote].
.类名{    属性:属性值1;属性2:属性值2;属性3:属性值3;}
标签调用的时候用 class=“类名” 即可。

类选择器最大的优势是可以为元素对象定义单独或相同的样式。

小技巧:

  1. 长名称或词组可以使用中横线来为选择器命名。

  2. 不建议使用“_”下划线来命名css选择器。

输入的时候少按一个shift键:

浏览器兼容问题(比如使用_tips的选择器命名,在IE6是无效的)

能良好区分JavaScript变量命名(JS变量命名是用“_”)

  1. 不要纯数字、中文等命名,尽量使用英文字母来表示。

命名规范:见附件(Web前端开发规范手册.doc)

命名是我们通俗约定的,但是没有规定必须用这些常用的命名。

多类名选择器


我们可以给标签指定多个类名,从而达到更多的选择目的。

注意:

  1. 样式显示效果跟HTML元素中的类名先后顺序没有关系,受css样式书写的上下顺序有关。

  2. 各个类名中间用空格隔开。

多类名选择器在后期布局比较复杂的情况下,还是较多使用的。

id选择器


id选择器使用“#”进行标识,后面紧跟id名,其基本语法格式如下:

#id{ 属性:属性值1;属性2:属性值2;属性3:属性值3;}

该语法中,id名即为HTML元素的id属性值,大多数HTML元素都可以定义为id属性,元素的id值是唯一的,只能对应于文档中某一个具体的元素。

用法基本和类选择器相同。

id选择器和类选择器区别


W3C标准规定,在同一个页面内,不允许有相同名字的id对象出现,但是允许相同名字的class。

类选择器(class)好比人的名字,是可以多吃重复使用的 比如 张伟,王维,等

id选择器 好比人的身份证号码,全中国是唯一的,不得重复,只能使用一次。

总结: 类选择器和id选择器的区别就是在使用次数上。

通配符选择器


通配符选择器用“*”号表示,它是所有选择器中作用范围最广的,能匹配页面中所有的元素。其基本语法格式如下:

*{ 属性:属性值1;属性2:属性值2;属性3:属性值3;}

例如下面的代码,使用通配符选择器定义css样式,清除所有HTML标记的默认边距。

*{

margin :0; 定义外边距

padding:0;定义内边距

}

注意:

这个通配符选择器,就像我妈的电影明星,想想他就好了,但是他不会和你过日子。。所以这个选择器,我妈认识就好了,平时工作很少用。

伪类选择器


首先,这也是一个选择器,伪类选择器用于向某些选择器添加特殊的效果。比如给链接添加特殊效果,比如可以选择 第1个,第n个元素。

为了和我们刚才学的类选择器相区别, 类选择器是一个点,比如 .demo{} 而我们的伪类 用 2个点 就是冒号 比如 :link{}

链接伪类选择器


  • :link 未访问的链接

  • :visited 已访问的链接

  • :hover 鼠标移动到链接上

  • :active 选定的链接

注意写的时候,他们的顺序尽量不要颠倒 安装 lvha的顺序。 love hate 记忆法 或者 lv包包 非常 hao

结构(位置)伪类选择器(CSS3)

  • :first-child:选取属于其父元素的首个子元素的指定选择器

  • :last-child:选取属于其父元素的最后一个子元素的指定选择器

  • :nth-child(n):匹配属于其父元素的第N个子元素,不论元素的类型(eg:n可以为even:第偶数个;或者odd:第基数个;或者为n,2n,2n-1等公式)

  • :nth-last-child(n):选择器匹配属于其元素的第N个子元素的每个元素,不论元素的类型,从最后一个子元素开始计数。n可以是数字,关键词或公式。

目标伪类选择器


:target目标伪类选择器,选择器可用于选取当前活动的目标元素:

:target{
  color:red;
  font-size:30px;
}

你可能感兴趣的:(CSS)