CSS2.1大纲梳理(1)

元素

替换元素和非替换元素

替换元素

用来替换元素的内容并非由文档内容直接表示。
如:imginputtextareaselect等。

<img src="some-url.png">

非替换元素

其内容由用户代理(通常是浏览器)在元素本身生成的框中进行显示。
如:divspanh1等元素。

块级元素和行内元素

块级元素

块级元素生成一个元素框,它会填充父元素的内容区,旁边不能有其他元素。如:
<p><div>

行内元素

行内元素是在一个文本行内生成元素框,这些元素不会在它们之前或之后生成“分隔符”,所以可以出现在另一个元素的内容中,而不破坏其显示。如:
<a><span>

引入CSS

link标记

<link rel="stylesheet" href="some-url" type="text/css" >

以上是link常用的属性,link还有一个media属性,可以用于在不同的显示设备上显示不同的效果。
同时,link的title属性用于向用户提供一个可选的样式,用户可以在浏览器的菜单中(如果浏览器支持)选择自己想要使用的样式表。

style元素

<style type="text/css">
/* Here is your own styles. */
</style>

@import指令

<style type="text/css">
@import url("some-url")
@import "another-url"
/* Here is your own styles. */
</style>

将@import放在style块中时,必须确保它(们)在style中最靠前的位置。

内联样式

<div style="..."></div>
<span style="..."></span>

选择器

元素选择器

文档的元素就是选择器本身。如:
body {...}
h1 {...}

通配符

“*”用于匹配所有元素。如:
* {font-size: 12px;}

类选择器

通过元素标签中的“class”属性进行选择。如:
元素:<div class="my-own-style"></div>
选择器:.my-own-style {...}

ID选择器

通过元素ID进行选择。如:
元素:<div id="ele"></div>
选择器:#ele {...}
虽然理论上所有元素应该拥有唯一的ID。但是,在多个元素具有相同ID的情况下,ID选择器的样式将使用在所有具有此ID的元素上。
HTML中的类选择器和ID选择器均是大小写敏感的。

属性选择器

属性选择器用于选取具有某个或某些属性的元素。
如:h1[class]a[href][title]*[title]等。
除此之外,还可以根据属性的值对元素进行选择。

完整属性值

完全属性值匹配要求属性的值以及值出现的顺序完全匹配。

部分属性值

整体属性中包含名为val的样式(注:此处val必须是完整的属性值名称,不能是属性值名称的一部分):
el[attr~="val"]
整体属性以val开头(注:val必须出现在所有属性值最前面,否则不生效):
el[attr^="val"]
整体属性以val结尾(注:val必须出现在所有属性值最后面,否则不生效):
el[attr$="val"]
整体属性中包含val字符串(不必是完整的属性值):
el[attr*="val"]
属性以val-开头或者等于val:
el[attr|="val"]
此选择器多用于lang属性。如:
*[lang|="en"]可以用于选择以下元素:

<div lang="en"></div>
<div lang="en-us"></div>

文档结构选择器

父子元素:在文档结构树上紧邻的两层所构成的层次包含(继承)关系。
后代元素:在文档结构树中存在继承关系,但是这些节点可能不处于直接相邻的两层。如爷爷与孙子、爷爷与曾孙子之间的关系。当然,父子关系也属于后代关系的一种。

后代选择器

el1 el2 {attr: val}
使用此选择器,el1所包含的所有el2元素均会被选中。

子元素选择器

el1 > el2 {attr: val}
使用此选择器,除非el1el2处于直接相邻的两层,否则el2不会被选中。

相邻兄弟元素选择器

el1 + el2 {attr: val}
选择的是紧邻着e1的e2元素,如果e1前面还有e0,则e0不会被选中。

如果你熟悉jQuery,你会发现CSS的选择器与jQuery对应选择器的行为是一致的,这有助于大家理解和记忆选择器。但是jQuery提供的选择器种类远远多余CSS提供的选择器。

思考:

对于

<ul>
    <li class="active">First</li>
    <li>Second</li>
    <li>Third</li>
    <li>Forth</li>
</ul>

下面两种选择器各是什么效果?

1、

li.active + li {
    font-weight: bold;
}

2、

li + li {
    font-weight: bold;
}
相邻元素选择器测试

伪类和伪元素

伪类

伪类是一种“假想”的类,通常情况下,你都无法在HTML代码中找到有任何地方显示地指定了某个元素为一个伪类。如,你不会看到一个链接具有以下的样式:<a class="visited">link</a>。这种写法虽然为锚指定了一个类,但是这个类是一个具体的visited类,而非我们想要的:visited伪类。
目前,CSS中主要有以下几个伪类:linkvisitedfocushoveractivefirst-childlang等。
在CSS中,伪类的顺序很重要,推荐的顺序为link->visited->focus->hover->active,大家可以思考一下为什么会推荐这样的顺序。
此外,还需要特别注意first-child的用法,因为该伪类与大家所见到的字面意思有一些的出入。请大家思考一下,以下代码最终选择到的是哪些元素?

<html>
     <head>
        <style type="text/css">
          li:first-child {
            font-weight: bold;
          }
        </style>
    </head>
    <body>
        <ul>
          <li>父选项-1</li>
          <li>父选项-2
             <ol>
                <li>子选项-1</li>
                <li>子选项-2</li>
                <li>子选项-3</li>
             </ol>
          </li>
          <li>父选项-3</li>
        </ul>
    </body>
</html>

伪元素

文档中的一种假想元素,该元素在文档中并无实体标签与其对应。

label[required]:after {/*注:CSS3中,应该为::after*/
    content: "*";
    color: red;
}

将会使以下代码产生一般的“必填”项的效果:

<label required>Name</label>
<input type="text"></input>
使用伪元素达到简单的必填表单效果

也可以使用伪元素实现计数器的功能。

<style type="text/css">
    body {
        counter-reset: counter 0;
    }

    .counter {
        counter-increment: counter;
    }

    .counter::before {
        content:counter(counter) ' - ';
    }
</style>

<div class="counter">元素</div>
<div class="counter">字体</div>
<div class="counter">定位</div>

这样,不用加入任何的JavaScript代码,就可以完成计数器功能。上面的代码段可以得到以下效果:
伪元素计数效果
<style>
    .blockquote:before {
      content: open-quote;
    }
    .blockquote:after {
      content: close-quote;
    }
</style>

<p class="blockquote">简单写一句放,展示一下效果。</p>
使用伪元素添加内容

再加一些样式,便可达到更好的效果。


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

推荐阅读更多精彩内容