1.1.基本选择器

  • 通配符选择器(*)
          通配符选择器的使用方法如下

    *{margin:0px; padding:0px;} //*代表所有的
  • ID选择器(#)
      
    ID选择器的使用方式如下:
    *#intro {font-weight:bold;}//也可以省略通配符 
     #intro{font-weight:bold;} //两种方式是一样的。

    不同于其他选择器,id选择器有以下特点
     规范: 同一个id,在一个网页中只能标注一个元素。
      如果有同名id ,则在CSS中用ID选择器时,依旧会匹配所有的同名id元素。只是这么使用的时候会有以下的弊端:
                  1.不符合规范,因为规范要求的是一个id只能被一个元素使用。
                  2.语义的二义性。一般id我们都是作为标示符使用的,一个id只能用来标注一个元素。
                  3.在JS DOM(getElementById)操作或者是jquery("#xx")选择页面中元素时,返回的仅是第一个被找到的素。

  • 类选择器(.)
        类选择器使用比较简单,使用方式如下:

    *.important {color:red;}   //第一种使用方式
     .important {color:red;}  //第二种使用方式,推荐第二种
  • 属性选择器([])
     
         属性选择器用来选择指定属性的 HTML 元素。使用方式如下:
    [title]{ color:red; }  //为带有 title 属性的所有元素设置样式:
    
    [title~=hello] { color:red; }//为包含指定值的 title 属性的所有元素设置样式
    
    属性选择器一览表
    选择器 描述
    [attribute] 用于选取带有指定属性的元素。
    [attribute=value] 用于选取带有指定属性和值的元素。
    [attribute~=value] 用于选取属性值中包含指定词汇的元素。
    [attribute|=value] 用于选取带有以指定值开头的属性值的元素,该值必须是整个单词。
    [attribute^=value] 匹配属性值以指定值开头的每个元素。
    [attribute$=value] 匹配属性值以指定值结尾的每个元素。
    [attribute*=value] 匹配属性值中包含指定值的每个元素。
     ========================================================================================================================
       在属性选择器中 [attribute~=value] 与 [attribute*=value] , [attribute|=value] 与 [attribute^=value] 的用法 在描述上很相似,很容易混淆:
    <img title="hello world"/>
    
      对于以上的元素  [title~=hello],[title*=hello]均能匹配,但是 [title~=hell]不能匹配,而[title*=hell]可以匹配,
    
     因为[attribute~=value] 匹配时要求value是一个“单词”,而 [attribute*=value]匹配时,是以正则表达式规则进行匹配
    
    
    同理,也可以类推出 [attribute|=value] 与 [attribute^=value]也是已类似的规则匹配,前者要求是以单词开头,而后者仅仅要求以xxxxx字符串开头即可.
    
    注: 这里所说的单词,并不是我们严格意义上的单词,比如 asdasd wasdas, 这里 asdasd wasdas对于计算机来说就是两个单词。但是as@re# 这种含有特殊字符的对于计算机来说就不是单词。
  • 伪类选择器(:)

    CSS2规则中所允许使用的伪类选择器

    
    
    CSS3中伪类选择器使用以及各浏览器的支持情况
    属性 描述 CSS
    :active 向被激活的元素添加样式。 1
    :focus 向拥有键盘输入焦点的元素添加样式。 2
    :hover 当鼠标悬浮在元素上方时,向元素添加样式。 1
    :link 向未被访问的链接添加样式。 1
    :visited 向已被访问的链接添加样式。 1
    :first-child 向元素的第一个子元素添加样式。 2
    :lang 向带有指定 lang 属性的元素添加样式。 2
     
    
    
    ===========================================================================================================
    
    常见的CSS3的规则  
    属性 描述 CSS
    :nth-child() 匹配父元素的第n个子元素 3
    :nth-of-type() 匹配某父元素下第几个某一个类型的元素 3
    :empty { sRules } 匹配没有任何子元素(包括text节点)的元素 3
    :checked { sRules } 匹配用户界面上处于选中状态的元素

    (用于input type为radio与checkbox时)

    3
          
      CSS3的这些规则大部分在IE--8中都是不能使用的,  关于CSS3的一些伪类选择器及其使用,详细请见CSS参考手册
  • 伪元素选择器(:或者::)
     

     常见的伪元素选择器如下:

    选择符 版本 描述
    :first-letter/E::first-letter CSS1/3 设置对象内的第一个字符的样式。
    :first-line/E::first-line CSS1/3 设置对象内的第一行的样式。
    :before/E::before CSS2/3 设置在对象前(依据对象树的逻辑结构)发生的内容。用来和content属性一起使用
    :after/E::after CSS2/3 设置在对象后(依据对象树的逻辑结构)发生的内容。用来和content属性一起使用
    ::placeholder CSS3 设置对象文字占位符的样式。
    ::selection CSS3 设置对象被选择时的颜色。

    CSS3推荐使用::写法,用以区分伪类选择器和伪元素选择器,但是使用:写法依旧有效。

    但是在使用:first-letter/E::first-letter时,IE6在使用该选择符时有个显式的BUG:选择符与包含规则的花括号之间不能紧挨    着,需留有空格或换行。

2.基本选择器的组合

基本选择器组合结果的复杂选择器无外乎以下几种:兄弟选择器,子选择器,后代选择器,组合选择器,群组选择器。

  • 兄弟选择器(+)

    兄弟选择器又称邻近选择器,选择邻近的元素.使用方式如下:

    selector1+selector2{
    } //由两个基本选择器,==》组合选择器


  • 子选择器(>)

    选择器,选择的是直接后代中所有符合条件的元素。

         selector1>selector2{
       color:red;
    }
  • 后代选择器(空格)

      后代选择器,选择的是子孙后代中所有符合条件的元素

    使用方式:
    
    selector1 selector2{
    color:red;
    } //A B是基本选择器
  • 组合选择器()

         组合选择器,是两个基本选择器同时使用的情况,匹配需同时满足多个基本选择器

    使用方式如下:
    
    selector1selector2{
    color:red;
    }

      

  • 群组选择器(,)

         群组选择器:选择器同时使用时,多个选择器之间是相互独立的
  • selector1,selector2{
    
    } //第一种
    =========================
    ========================= 两种使用方式,效果是一样的,只是第一种有利于代码的复用。
    selector1{ }
    selector2{ } //第二种

==================================================================

==================================================================、

=====================================未完待续....下一篇,各类选择器的优先级

本篇中只是大致叙述了一下,CSS选择器的种类,讲的也比较浅显---如果详细学习,推荐

http://www.css88.com/book/css/selectors/pseudo-classes/index.htm...

CSS系列------选择器和选择器的优先级的更多相关文章

  1. CSS系列之后代选择器、子选择器和相邻兄弟选择器

    后代选择器比子选择器的范围大,包含子选择器,且包含子选择器的“子孙”选择器,后代选择器使用"空格"符号间隔选择器 子选择器:子选择器只是父选择器的一级子元素,使用"> ...

  2. css系列教程1-选择器全解

    全栈工程师开发手册 (作者:栾鹏) 一个demo学会css css系列教程1-选择器全解 css系列教程2-样式操作全解 css选择器全解: css选择器包括:基本选择器.属性选择器.伪类选择器.伪元 ...

  3. 【CSS系列-选择器优先级总结】

    转:http://www.cnblogs.com/dolphinX/p/3511300.html 容易被忽略CSS特性   CSS初学感觉很简单,但随着学习的深入才感觉CSS的水由多深,平常总会遇到各 ...

  4. 我给女朋友讲编程CSS系列(2)- CSS语法、3大选择器、选择器优先级

    首先看一下使用Css设置h1标签字体颜色和大小的例子,效果图如下: 新建一个网页test.html,然后复制粘贴下面的内容: <html> <head> <style t ...

  5. CSS魔法堂:选择器及其优先级

    一.前言    首先看看一道阿里这期网申的题目吧! 1.找出下面优先级相同的选择器 A. img.thumb:after B.[data-job="frontend"]::firs ...

  6. css样式表和选择器的优先级以及position元素属性值的区别

    css样式表优先级 问题:当同一个HTML元素被不止一个样式定义时,会使用哪个样式呢? 答:一般而言,所有的样式会根据下面的规则层叠于一个新的虚拟样式表中,其中数字4拥有最高的优先权. 1.浏览器缺省 ...

  7. css笔记09:选择器优先级

    1. (1) <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

  8. CSS选择器,选择器的优先级

    CSS选择器 CSS基本语法 选择器 + 声明块 选择器 - 通过CSS选择器选中页面中的指定元素,下面会重点写. 声明块 - 选择器后面跟着的是声明块,使用{}括起来,由一个个声明组成,声明由名值对 ...

  9. css中常用的选择器和选择器优先级

    css常用的选择器:类选择器,id选择器,元素选择器,伪类选择器,伪元素选择器,属性选择器. 选择器的优先级由四个部分组成:0,0,0,0 一个选择器的具体优先级如下规则确定: ID选择器 加 0,1 ...

随机推荐

  1. webpack html

    调用了原模板 修改路径 使html放在JS外面 可以传递参数 多个html指定对应chunks 除了某些模块其余的都被引入

  2. PPLB条码打印

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

  3. 通过ssh秘钥的方式可以连接上CE68交换机

    结论:按照CE68交换机的用户手册中的指导,可以通过ssh 秘钥的方式连接上交换机. 1.先按照eNSP连接到网卡的方式,给CE68配置一个ip地址: 192.168.56.2 2.按照交换机的用户指 ...

  4. 原生JS实现音乐播放器!

      前  言            最近在复习JS,觉得音乐播放器是个挺有意思的东西,今天就来用我们最原生的JS写一个小小的音乐播放器~ 主要功能: 1.支持循环.随机播放 2.在播放的同时支持图片的 ...

  5. 聊聊VUE中的nextTick

    在谈nextTick之前,先要说明一件事,可能在我们平时使用vue时并没有关注到,事实上,vue执行的DOM更新是异步的. 举个栗子: <template> <div class=& ...

  6. JS实现时钟特效

    <!DOCTYPE html><html><head lang="en"><meta charset="UTF-8"& ...

  7. PHP 注释 数据类型 变量的定义/输出 类型的获取/转换 可变变量

    注释方法: 1,单行注释:     // 2,  多行注释:     /*   */ 二,数据类型 1,integer(整数型):在三十二位操作系统中它的有效范围是:-2147483648~+2147 ...

  8. Appium python自动化测试系列之移动自动化测试前提(一)

    1.1 移动自动化测试现状 因为软件行业越来越发达,用户的接受度也在不断提高,所以对软件质量的要求也随之提高,当然这个也要分行业,但这个还是包含了大部分.因为成本.质量的变化现在对自动化测试的重视度越 ...

  9. ADO.NET知识点

    今天复习到了ADO.NET,就把他们的知识梳理总结出来 ADO.NET 是一组向 .NET 程序员公开数据访问服务的类.提供了对各种关系数据.XML 和应用程序数据的访问. 所有的数据访问类位于Sys ...

  10. [extjs(2)] extjs第一个组件treepanel

    刚刚在接触extjs这个前段插件,由于公司是用这个来做前段的,所以有必要花点时间来掌握一下,下面是我自己的非常浅的学习总结,后期会慢慢添加的!! 一.TreePanel基本配置参数: animate: ...