第2章 CSS3选择器-3

2.6 语言伪类选择器

使用语言伪类选择器来匹配使用语言的元素是非常有用的,特别是用于多语言版本的网站,其作用更是明显。可以使用它来根据不用语言版本设置页面的字体风格。

2.6.1 语言伪类选择器语法

语言伪类选择器是根据元素的语言编码匹配元素。这种语言信息必须包含在文档中,或者与文档关联,不能从CSS指定。为文档指定语言,有两种方法可以表示。如果使用HTML5,直接可以设置文档的语言。例如:

<!DOCTYPE html>
<html lang="en-US">

另一种方法就是手工在文档中指定lang属性,并设置对应的语言值。例如:

<body lang="fr">

语言伪类选择器允许为不同的语言定义特殊的规则,这在多语言版本的网站用起来是特别方便的。
E.lang(language)表示选择匹配E的所以元素,且匹配元素指定了lang属性,而且其值为language

2.6.2 浏览器兼容性

语言伪类选择器在IE7及以下版本中还不被支持。

2.6.3 实战体验:定制不用语言版本引文风格

<!DOCTYPE html>
<html lang="en-US">
<head>
    <meta charset="UTF-8">
    <title>语言伪类选择器运用</title>
</head>
<body>
    <p>WWF's goal is to:
    <q cite="http://www.wwwf.org">
        build a future where people live in harmony with nature
    </q>we hope they succeed.
    </p>
</body>
</html>
lang="en-US"
<!DOCTYPE html>
<html lang="fr">
<head>
    <meta charset="UTF-8">
    <title>语言伪类选择器运用</title>
</head>
<body>
    <p>WWF's goal is to:
    <q cite="http://www.wwwf.org">
        build a future where people live in harmony with nature
    </q>we hope they succeed.
    </p>
</body>
</html>
lang="fr"

2.7 UI元素状态伪类选择器

UI元素状态伪类选择器也是CSS3选择器模块组中的一部分,主要用于form 表单元素上,以提高网页的人机交互、操作逻辑以及页面的整体美观,使表单页面更具个性与品位,而且使用户操作页面表单更便利和简单。

2.7.1 UI元素状态伪类选择器语法

UI元素的状态一般包括:启用、禁用、选中、未选中、获得焦点、失去焦点、锁定和待机等。在HTML元素中有可用和不可用状态,例如表单中的文本输入框;HTML元素中海油选中和未选中状态,例如表单中的复选按钮和单选按钮。这几种状态都是CSS3选择器中常用的状态伪类选择器。详细说明如下所示:

选择器 类型 功能描述
E:cheched 选中状态伪类选择器 匹配选中的复选按钮或单选按钮表单元素
E:enabled 启用状态伪类选择器 匹配所有启用的表单元素
E:disabled 不可用状态伪类选择器 匹配所有禁用的表单元素

2.7.2 浏览器兼容性

除了IE浏览器外,各主流浏览器对UI元素状态选择器的支持都非常好,但IE9页开始全面支持这些UI元素状态伪类选择器。

2.7.3 实战体验:Bootstrap的表单元素UI状态

略(p37-p41) 太长了/(ㄒoㄒ)/~~

2.8 结构伪类选择器

伪类可以将一段并不存在的HTML当作独立元素来定位,或是找到无法使用其他简单选择器就能定位到的切实存在的元素。因此CSS3给伪类选择器引入一种“结构伪类选择器”。这种选择器可以根据元素在文档树中的某些特性(如相对位置)定位到它们。也就是说,通过文档树结构的相互关系来匹配特定的元素,从而减少HTML文档对ID或类名的定义, 帮助你保持干净和整洁。

2.8.1 重温HTML的DOM树

所有的结构伪类都是基于HTML文档树的,也称作文档对象模型(DOM)。文档树是HTML页面的层级结构。它由元素、属性和文本组成,它们都是一个节点,就像公司的组织结构图一样。下面看一个简单的HTML文档。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>HTML DOM树形结构图</title>
</head>
<body>
    <div>
        <ul>
            <li>one</li>
            <li>two</li>
            <li>three</li>
        </ul>
        <div>abc</div>
        <p>para</p>
        <div>def</div>
        <p>para</p>
        <b>ghi</b>
    </div>
</body>
</html>
HTML DOM树形结构

2.8.2 结构伪类选择器语法

选择器 功能描述
E:first-child 作为父元素的第一个子元素的元素E。与E:nth-child(1)等同
E:last-child 作为父元素的最后一个子元素的元素E。与E:nth-last-child(1)等同
E:root 选择匹配元素E所在文档的根元素。在HTML文档中,根元素始终是html,此时该选择器与html类型选择器匹配的内容相同
E F:nth-child(n) 选择父元素E的第n个子元素F。其中n可以是整数(1,2,3),关键字(even,odd),可以是公式(2n+1,-n+5),而且n值起始值为1,而不是0
E F:nth-last-child(n) 选择元素E的倒数第n个子元素F。此选择器与E F:nth-child(n)选择器计算顺序刚好相反,但使用方法都是一样的,其中nth-last-child(1)始终匹配的是最后一个元素,与last-child等同
E:nth-of-type(n) 选择父元素内具有指定类型的第n个E元素
E:nth-last-of-type(n) 选择父元素内具有指定类型的倒数第n个E元素
E:first-of-type 选择父元素内具有指定类型的第一个E元素,与E:nth-of-type(1)等同
E:last-of-type 选择父元素内具有指定类型的倒数第一个E元素,与E:nth-last-of-type(1)等同
E:only-child 选择父元素只包含一个子元素,且该子元素匹配E元素
E:only-of-type 选择父元素只包含一个同类型的子元素,且该子元素匹配E元素
E:empty 选择没有子元素的元素,而且该元素也不包含任何文本节点

2.8.3 浏览器兼容性

CSS3结构伪类选择器在主流浏览器下运行都非常的完美,只是在IE9及以下版本的浏览器中无法正常运行。

2.8.4 结构伪类选择器中的n是什么

在结构伪类选择器中,有4个伪类选择器接受参数n。

  1. :nth-child(n)
  2. :nth-last-child(n)
  3. :nth-of-type(n)
  4. :nth-last-of-type(n)

在实际应用中,这个参数n可以是整数(1,2,3),关键字(even,odd),可以是公式(2n+1,-n+5),而且n值起始值为1,而不是0。换句话说,当参数n的值为0时,选择器将选择不到任何匹配的元素。

结构伪类选择器中的参数按常用的情况划分为七种情形。

  1. 参数n为具体的数值(大于0的整数)
  2. 参数n为表达式"n * length"(选择n的倍数)
  3. 参数n为表达式"n + length"(选择大于或等于length的元素)
  4. 参数n为表达式"-n + length"(选择小于或等于length的元素)
  5. 参数n为表达式"n * length + b"(其中b是您想设置的偏移值,表示隔length个元素选中第 n * length + b个元素。)
  6. 参数为关键词“odd”(选择系列中的奇数元素)
  7. 参数为关键词“even”(选择系列中的偶数元素)

2.8.5 结构伪类选择器的使用方法详解

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>结构伪类选择器的使用</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        ul{
            margin: 50px auto;
            width: 400px;
            list-style-type: none outside none;
        }
        li{
            display: inline-block;
            margin: 5px;
            padding: 5px;
            width: 50px;
            height: 50px;
            font: bold 30px/50px arial;
            background: #000;
            color: #fff;
            border-radius: 50px;
            text-align: center;
        }
    </style>
</head>
<body>
    <ul>
        <li>1</li><li>2</li><li>3</li><li>4</li><li>5</li><li>6</li><li>7</li><li>8</li><li>9</li><li>10</li><li>11</li><li>12</li><li>13</li><li>14</li><li>15</li><li>16</li><li>17</li><li>18</li><li>19</li><li>20</li>/ul>
</body>
</html>
页面初始果图
1. :first-child的使用
ul > li:first-child{
    background-color: green;
}
:first-child效果图
2. :last-child的使用
ul > li:last-child{
    background-color: blue;
}
:last-child效果图
3. :nth-child的使用

(1)nth-child(3)

ul > li:nth-child(3){
    background-color: yellow;
}
:nth-child(3)效果图

(2)nth-child(n)

ul > li:nth-child(n){
    background-color: orange;
}
:nth-child(n)效果图

(3)nth-child(2n)

ul > li:nth-child(2n){
    background-color: blue;
}
:nth-child(2n)效果图

(4)nth-child(2n+1)

ul > li:nth-child(2n+1){
    background-color: blue;
}
:nth-child(2n+1)效果图

(5)nth-child(n+5)

ul > li:nth-child(n+5){
    background-color: blue;
}
:nth-child(n+5)效果图

(6)nth-child(-n+5)

ul > li:nth-child(-n+5){
    background-color: blue;
}
:nth-child(-n+5)效果图

(7)nth-child(4n+1)

ul > li:nth-child(4n+1){
    background-color: blue;
}
:nth-child(4n+1)效果图
4. :nth-last-child的使用
ul > li:nth-last-child(4){
    background-color: blue;
}
:nth-last-child效果
5. :nth-of-type的使用【略】
6. :nth-last-of-type的使用【略】
7. :first-of-type:last-of-type的使用【略】
8. :only-child的使用【略】
9. :only-of-child的使用【略】
10. :empty的使用【略】

2.8.6 实战体验:CSS3美化表格

略(p61-p66) 太长了/(ㄒoㄒ)/~~

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

推荐阅读更多精彩内容

  • (1). 阴影模糊半径与阴影扩展半径的区别:阴影模糊半径:此参数可选,其值只能是为正值,如果其值为0时,表示阴影不...
    Leisure_blogs阅读 1,461评论 0 6
  • 一、CSS选择器常见的有几种? 基本选择器 通配选择器~选择文档中所有的html元素,用一个*表示 元素选择器~选...
    dengpan阅读 958评论 0 3
  • 其实平时用得多的选择器无非也就是那么几个,时间久了,许多不常用的选择器就慢慢忘记了。为了不让自己忘记这些选择器,今...
    盛夏晚清风阅读 1,801评论 0 5
  • 一、基本选择器 回顾选择器 通配符选择器、元素选择器、类选择器、ID选择器、后代选择器 新增基本选择器 子元素选择...
    越IT阅读 1,141评论 0 3
  • CSS选择器结构逻辑图 接下来按照结构逻辑图具体讲解各个选择器的作用及用法; 基本选择器 基本选择器主要有以下5类...
    FoolishFlyFox阅读 554评论 0 8