CSS 自学笔记(中)

传送门:


继承、层叠和特殊性


继承

CSS 样式不仅作用于某一个 HTML 标签元素,还对这个标签元素的所有子标签元素都起作用。

有一些样式是不具备继承特性的,比如设置边框:

p{
  border :1px solid red;
}

特殊性

为同一个元素设置不同的样式,最终起作用的样式由权值来确定。

  • id 选择器: 100
  • 类选择器: 10
  • 标签选择器: 1

而来自继承的样式所具有的权值可等价于 0.1。

在计算权值的时候,使用加法叠加就可以了:

#footer .note p {
  color: yellow;
}
100 + 10 + 1 = 111

重要性

对于某种特殊情况,需要将某个样式设置为最高权值:

p {
  color: red !important;
}

一定要写在分号前

浏览器默认的样式 < 网页制作者样式 < 用户自己设置的样式 < !important

文字排版


  • font-family:"Microsoft Yahei" 字体
  • font-size: 12px 字体大小
  • font-weight:bold:设置为粗体样式
  • font-style:italic:设置为斜体样式
  • text-decoration:underline:文字设置下划线
  • text-decoration:line-through:删除线
  • text-indent:2em:缩进

注意:2em的意思就是文字的2倍大小。

  • line-height:2em:行高
  • word-spacing:50px:单词间距
  • letter-spacing:20px: 字母间距
  • text-align:center 水平居中对齐

盒模型


在 CSS 样式中,HTML 标签元素大体被分为三种不同的类型:块级元素内联元素(又叫行内元素)和内联块级元素

块状元素 (block)

诸如 <div><p><h1><form><ul><li> 就是块状元素。我们可以为某个样式添加属性,以使其成为块状元素:

span{
  display: block;
}
  • 块状元素的首尾会空一行
  • 宽度默认等于父容器

内联元素 (inline)

诸如 <span><a><label><strong><em> 就是内联元素。我们可以为某个样式添加属性,以使其成为内联元素:

span{
  display: inline;
}
  • 高度、宽度、边距不可设置
  • 宽度等于内容的宽

内联块状元素 (inline-block)

诸如 <img><input> 就是内联块状元素。我们可以为某个样式添加属性,以使其成为内联块状元素:

span{
  display: inline-block;
}
  • 既具备内联元素内容都在一行内的特点,又具备块状元素宽、高、边距离可设置的特点。

盒子模型


下面是盒子模型常用的属性:

  • padding:内边距
  • margin:外边距
  • border:边框

我们可以通过在这些属性的名字后边添加 属性 - 下一级属性 的方法来指定某一更加具体的属性,如:

  • border-style: dashed(虚线)| dotted(点线)| solid(实线);
  • border-color: #888;
  • border-width: 12px | thin | medium | thick

甚至指定某一侧的样式:

border-top: 1px solid red;
padding-right: 10px; 
margin-left: 100px;

也可以按照 的方式来简单定义:

div{padding:20px 10px 15px 30px;}
盒子模型

在盒子模型理论中,宽度指的是 margin-left + border-left + padding-left + padding-right + border-right + margin-right ,高度同理。

布局模型


流动模型

  • 块状元素 会按照自上而下的顺序排列
  • 内联元素 会按照从左到右的顺序排列

浮动模型

浮动模型的目的是让 块状元素 呈现水平排列。

所有元素默认都是不可浮动的,但我们可以手动设置为浮动:

div {
    width: 200px;
    height: 200px;
    border: 2px red solid;
    // 设置浮动模型
    float: left; 
}

层模型

1. 绝对定位 (position:absolute)

在样式中添加代码以进行绝对定位:

div{
    width: 200px;
    height: 200px;
    border: 2px red solid;
    // 设置绝对定位
    position: absolute;
    left: 100px;
    top: 50px;
}

在绝对定位中,元素的位置是相对于 [距离最近的] [具备定位属性的] 父元素而言的。如果没有找到这样的父元素,那么就会以 body 元素作为定位参考。举个例子

首先定义 a、b 两个方框样式:

a {
  width: 100px;
  height: 100px;
  border: 3px red solid;
  position:absolute;
  left: 100px;
  top: 100px;
}
b {
  width: 50px;
  height: 50px;
  border: 3px blue solid;
  position:absolute;
  left: 125px;
  top: 125px;
}

然后这样使用它们:

<body>
    <a></a><b></b>
</body>

看起来是这样:

如果把元素 b 改为 a 元素的子元素:

<body>
    <a><b></b></a>
</body>

看起来就是这样:

2. 相对定位(position:relative)

相对定位指的是相对于原本的位置,可以这么理解 :

元素在页面的实际位置 = 在页面正常文档流中的位置 + 偏移位置

注意:相对定位之后,正常文档流中的位置继续被占用着。

3. 固定定位(position:fixed)

固定定位的参考系就是整个浏览器的窗口。

固定定位的元素位置不会随滚动条滚动而变化不会受文档流的影响。(比如网页小广告)

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

推荐阅读更多精彩内容

  • 什么是选择器 每一条css样式声明(定义)由两部分组成,形式如下: 在{}之前的部分就是“选择器”,“选择器”指明...
    小挠许阅读 322评论 0 1
  • html 标签的意义 : 根标签,是网页的开始和结束 : 头部 很多描述属性 会显示在网页标题栏中 不会展...
    linyaDu阅读 855评论 0 1
  • 课程来自慕客网:http://www.imooc.com/code/49 另外有网易coursera合作的课程:网...
    喵在野阅读 1,745评论 3 30
  • 一 外部式css样式 (也可称为外联式)就是把css代码写一个单独的外部文件中,这个css样式文件以“.css...
    KunMitnic阅读 921评论 0 1
  • 今天我犯了一个错误,我不小心把家里的花瓶给打碎了,我怕爸爸回来会打我,就把碎的花瓶扫到垃圾袋里,把垃圾袋捆好...
    美俊汽车阅读 149评论 0 0