CSS

一、CSS的发展历程

  从HTML被发明开始,样式就以各种形式存在。不同的浏览器结合它们各自的样式语言为用户提供页面效果的控制。最初的HTML只包含很少的显示属性。 随着HTML的成长,为了满足页面设计者的要求,HTML添加了很多显示功能。但是随着这些功能的增加,HTML变的越来越杂乱,而且HTML页面也越来越臃肿。于是CSS便诞生了。

二、CSS 网页的美容师

  CSS的出现,拯救了混乱的HTML,当让更加拯救了我们web开发者。 让我们的网页更加丰富多彩。

  CSS的最大贡献就是: 让 HTML 从样式中解脱苦海, 实现了 HTML 专注去做 结构呈现。 而样式交给 CSS 后,你完全可以放心的早点洗洗睡了!

三、CSS初识

  CSS(Cascading Style Sheets) 美化样式

  CSS通常称为CSS样式表或层叠样式表(级联样式表),主要用于设置HTML页面中的文本内容(字体、大小、对齐方式等)、图片的外形(宽高、边框样式、边距等)以及版面的布局等外观显示样式。

  CSS以HTML为基础,提供了丰富的功能,如字体、颜色、背景的控制及整体排版等,而且还可以针对不同的浏览器设置不同的样式。

四、引入CSS样式表(书写位置)

4.1 内部样式表

  内嵌式是将CSS代码集中写在HTML文档的head头部标签中,并且用style标签定义,其基本语法格式如下:

<head>
<style type="text/CSS">
    选择器 {属性1:属性值1; 属性2:属性值2; 属性3:属性值3;}
</style>
</head>

  语法中,style标签一般位于head标签中title标签之后,也可以把他放在HTML文档的任何地方。

  type="text/CSS" 在html5中可以省略, 写上也比较符合规范, 所以这个地方可以写也可以省略。

4.2 行内式(内联样式)

  内联样式,又有人称行内样式、行间样式、内嵌样式。是通过标签的style属性来设置元素的样式,其基本语法格式如下:

<标签名 style="属性1:属性值1; 属性2:属性值2; 属性3:属性值3;"> 内容 </标签名>

  语法中style是标签的属性,实际上任何HTML标签都拥有style属性,用来设置行内式。其中属性和值的书写规范与CSS样式规则相同,行内式只对其所在的标签及嵌套在其中的子标签起作用。

4.3 外部样式表(外链式)

  链入式是将所有的样式放在一个或多个以.CSS为扩展名的外部样式表文件中,通过link标签将外部样式表文件链接到HTML文档中,其基本语法格式如下:

<head>
  <link href="CSS文件的路径"  rel="stylesheet" />
</head>

  注意: link 是个单标签哦!!!

  该语法中,link标签需要放在head头部标签中,并且必须指定link标签的三个属性,具体如下:

href:定义所链接外部样式表文件的URL,可以是相对路径,也可以是绝对路径。
type:定义所链接文档的类型,在这里需要指定为“text/CSS”,表示链接的外部文件为CSS样式表。
rel:定义当前文档与被链接文档之间的关系,在这里需要指定为“stylesheet”,表示被链接的文档是一个样式表文件。

4.4 三种样式表总结(位置)

样式表 优点 缺点 使用情况 控制范围
行内样式表 书写方便,权重高 没有实现样式和结构相分离 较少 控制一个标签(少)
内部样式表 部分结构和样式相分离 没有彻底分离 较多 控制一个页面(中)
外部样式表 完全实现结构和样式相分离 需要引入 最多,强烈推荐 控制整个站点(多)

五、CSS样式规则

  使用HTML时,需要遵从一定的规范。CSS亦如此,要想熟练地使用CSS对网页进行修饰,首先需要了解CSS样式规则,具体格式如下:

 

在上面的样式规则中:

  1. 选择器用于指定CSS样式作用的HTML对象,花括号内是对该对象设置的具体样式。
  2. 属性和属性值以“键值对”的形式出现。
  3. 属性是对指定的对象设置的样式属性,例如字体大小、文本颜色等。
  4. 属性和属性值之间用英文“:”连接。
  5. 多个“键值对”之间用英文“;”进行区分。

六、选择器(重点)

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

  选择器干啥的? 选择标签用的

七、CSS基础选择器

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

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

标签名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }  或者
元素名{属性1:属性值1; 属性2:属性值2; 属性3:属性值3; }

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

  标签选择器 可以把某一类标签全部选择出来 div span

7.2 类选择器

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

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

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

小技巧:

  1. 长名称或词组可以使用中横线来为选择器命名。
  2. 不建议使用“_”下划线来命名CSS选择器。
  3. 不要纯数字、中文等命名, 尽量使用英文字母来表示。

练习

<head>
        <meta charset="utf-8">
        <style>
        span {
            font-size: 100px;
        }
        .blue {
            color: blue;
        }
        .red {
            color: red;
        }
        .orange {
            color: orange;
        }
        .green {
            color: green;
        }
        </style>
    </head>
    <body>
        <span class="blue">G</span>
        <span class="red">o</span>
        <span class="orange">o</span>
        <span class="blue">g</span>
        <span class="green">l</span>
        <span class="red">e</span>
    </body>

7.3 多类名选择器

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

 

注意:

  1. 样式显示效果跟HTML元素中的类名先后顺序没有关系,受CSS样式书写的上下顺序有关。
  2. 各个类名中间用空格隔开。

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

<div class="pink fontWeight font20">亚瑟</div>
<div class="font20">刘备</div>
<div class="font14 pink">安其拉</div>
<div class="font14">貂蝉</div>

7.4 id选择器

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

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

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

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

7.5 id选择器和类选择器区别

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

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

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

  id选择器和类选择器最大的不同在于 使用次数上。

7.6 通配符选择器

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

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

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

* {
  margin: 0;                    /* 定义外边距*/
  padding: 0;                   /* 定义内边距*/
}

  但是一般都不用。。。

八、CSS字体样式属性

8.1 font-size:字号大小

  font-size属性用于设置字号,该属性的值可以使用相对长度单位,也可以使用绝对长度单位。其中,相对长度单位比较常用,推荐使用像素单位px,绝对长度单位使用较少。具体如下:

 

p {
        font-size=16px;    不要忘记 px 单位
}    

8.2 font-family:字体

  font-family属性用于设置字体。网页中常用的字体有宋体、微软雅黑、黑体等,例如将网页中所有段落文本的字体设置为微软雅黑,可以使用如下CSS样式代码:

p { 
        font-family:"微软雅黑","宋体"
}

  可以同时指定多个字体,中间以逗号隔开,表示如果浏览器不支持第一个字体,则会尝试下一个,直到找到合适的字体。

常用技巧

1. 现在网页中普遍使用14px+。
2. 尽量使用偶数的数字字号。ie6等老式浏览器支持奇数会有bug。
3. 各种字体之间必须使用英文状态下的逗号隔开。
4. 中文字体需要加英文状态下的引号,英文字体一般不需要加引号。当需要设置英文字体时,英文字体名必须位于中文字体名之前。
5. 如果字体名中包含空格、#、$等符号,则该字体必须加英文状态下的单引号或双引号,例如font-family: "Times New Roman";。
6. 尽量使用系统默认字体,保证在任何用户的浏览器中都能正确显示。

8.3 CSS Unicode字体

  在 CSS 中设置字体名称,直接写中文是可以的。但是在文件编码(GB2312、UTF-8 等)不匹配时会产生乱码的错误。xp 系统不支持 类似微软雅黑的中文。

  方案一: 你可以使用英文来替代。 比如 font-family:"Microsoft Yahei"。

  方案二: 在 CSS 直接使用 Unicode 编码来写字体名称可以避免这些错误。使用 Unicode 写中文字体名称,浏览器是可以正确的解析的。 font-family: "5FAE8F6F96C59ED1",表示设置字体为“微软雅黑”。

  可以通过escape() 来测试属于什么字体。

字体名称英文名称Unicode 编码
宋体 SimSun 5B8B4F53
新宋体 NSimSun 65B05B8B4F53
黑体 SimHei 9ED14F53
微软雅黑 Microsoft YaHei 5FAE8F6F96C59ED1
楷体_GB2312 KaiTi_GB2312 69774F53_GB2312
隶书 LiSu 96B64E66
幼园 YouYuan 5E7C5706
华文细黑 STXihei 534E65877EC69ED1
细明体 MingLiU 7EC6660E4F53
新细明体 PMingLiU 65B07EC6660E4F53

  为了照顾不同电脑的字体安装问题,我们尽量只使用宋体和微软雅黑中文字体.

8.4 font-weight:字体粗细

字体加粗除了用 b 和 strong 标签之外,可以使用CSS 来实现,但是CSS 是没有语义的。

font-weight属性用于定义字体的粗细,其可用属性值:normal、bold、bolder、lighter、100~900(100的整数倍)。
font-weight:700; 没有px

小技巧:

  数字 400 等价于 normal,而 700 等价于 bold。 但是我们更喜欢用数字来表示。 解析快。

8.5 font-style:字体风格

  字体倾斜除了用 i 和 em 标签之外,可以使用CSS 来实现,但是CSS 是没有语义的。

  font-style属性用于定义字体风格,如设置斜体、倾斜或正常字体,其可用属性值如下:

  1. normal:默认值,浏览器会显示标准的字体样式。
  2. italic:浏览器会显示斜体的字体样式。
  3. oblique:浏览器会显示倾斜的字体样式。(有兼容性问题

小技巧:

  平时我们很少给文字加斜体,反而喜欢给斜体标签(em,i)改为普通模式。

8.6 font:综合设置字体样式 (重点)

  font属性用于对字体样式进行综合设置,其基本语法格式如下:

选择器{font: font-style  font-weight  font-size/line-height  font-family;}

  使用font属性时,必须按上面语法格式中的顺序书写,不能更换顺序,各个属性以空格隔开
  注意:其中不需要设置的属性可以省略(取默认值),但必须保留font-size和font-family属性,否则font属性将不起作用。

九、CSS外观属性

9.1 color:文本颜色

color属性用于定义文本的颜色,其取值方式有如下3种:

  1. 预定义的颜色值,如red,green,blue等。
  2. 十六进制,如#FF0000,#FF6600,#29D794等。实际工作中,十六进制是最常用的定义颜色的方式。
  3. RGB代码,如红色可以表示为rgb(255,0,0)或rgb(100%,0%,0%)。

  需要注意的是,如果使用RGB代码的百分比颜色值,取值为0时也不能省略百分号,必须写为0%。

可以把 #ff0000简写成#f00

9.2 line-height:行间距

  ine-height属性用于设置行间距,就是行与行之间的距离,即字符的垂直间距,一般称为行高。line-height常用的属性值单位有三种,分别为像素px,相对值em和百分比%,实际工作中使用最多的是像素px

  一般情况下,行距比字号大7.8像素左右就可以了。

9.3 text-align:水平对齐方式

text-align属性用于设置文本内容的水平对齐,相当于html中的align对齐属性。其可用属性值如下:

  1. left:左对齐(默认值)
  2. right:右对齐
  3. center:居中对齐

9.4 text-indent:首行缩进

  text-indent属性用于设置首行文本的缩进,其属性值可为不同单位的数值、em字符宽度的倍数、或相对于浏览器窗口宽度的百分比%,允许使用负值, 建议使用em作为设置单位。

  1em 就是一个字的宽度 如果是汉字的段落, 1em 就是一个汉字的宽度

9.5 text-decoration 文本的装饰

text-decoration 通常我们用于给链接修改装饰效果

描述
none 默认。定义标准的文本。
underline 定义文本下的一条线。下划线 也是我们链接自带的
overline 定义文本上的一条线。
line-through 定义穿过文本下的一条线。

十、CSS复合选择器

  复合选择器是由两个或多个基础选择器,通过不同的方式组合而成的,目的是为了可以选择更准确更精细的目标元素标签。

10.1 交集选择器

  交集选择器由两个选择器构成,其中第一个为标签选择器(可以其他的),第二个为class选择器,两个选择器之间不能有空格,如h3.special。

  交集选择器 是 并且的意思。 即...又...的意思

比如:   p.one   选择的是: 类名为 .one  的 段落标签。 

  用的相对来说比较少,不太建议使用。

10.2 并集选择器

  并集选择器(CSS选择器分组)是各个选择器通过逗号连接而成的,任何形式的选择器(包括标签选择器、class类选择器id选择器等),都可以作为并集选择器的一部分。如果某些选择器定义的样式完全相同,或部分相同,就可以利用并集选择器为它们定义相同的CSS样式。

  并集选择器 和 的意思, 就是说,只要逗号隔开的,所有选择器都会执行后面样式。

比如  .one, p , #test {color: #F00;}  表示   .one 和 p  和 #test 这三个选择器都会执行颜色为红色。  通常用于集体声明。

10.3 后代选择器

  后代选择器又称为包含选择器,用来选择元素或元素组的后代,其写法就是把外层标签写在前面,内层标签写在后面,中间用空格分隔。当标签发生嵌套时,内层标签就成为外层标签的后代。

10.4 子元素选择器

  子元素选择器只能选择作为某元素子元素的元素。其写法就是把父级标签写在前面,子级标签写在后面,中间跟一个 进行连接,注意,符号左右两侧各保留一个空格。

 

  白话: 这里的子 指的是 亲儿子 不包含孙子 重孙子之类。

比如:  .demo > h3 {color: red;}   说明  h3 一定是demo 亲儿子。  demo 元素包含着h3。

练习

<div class="nav">    <!-- 主导航栏 -->
  <ul>
    <li><a href="#">公司首页</a></li>
    <li><a href="#">公司简介</a></li>
    <li><a href="#">公司产品</a></li>
    <li>
         <a href="#">联系我们</a>
         <ul>
                    <li><a href="#">公司邮箱</a></li>
                    <li><a href="#">公司电话</a></li>
         </ul>
    </li>
  </ul>
</div>
<div class="sitenav">    <!-- 侧导航栏 -->
  <div class="site-l">左侧侧导航栏</div>
  <div class="site-r"><a href="#">登录</a></div>
</div>

----------------------------------------------------------------------------

在不修改以上代码的前提下,完成以下任务:


  1. 链接 登录 的颜色为红色,同时主导航栏里面的所有的链接改为蓝色 (简单)

  2. 主导航栏和侧导航栏里面文字都是14像素并且是微软雅黑。(中等)

  3. 主导航栏里面的一级菜单链接文字颜色为绿色。(难)

10.5 伪类选择器

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

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

10.6 链接伪类选择器

  • :link /* 未访问的链接 */

  • :visited /* 已访问的链接 */

  • :hover /* 鼠标移动到链接上 */

  • :active /* 选定的链接 */

注意写的时候,他们的顺序尽量不要颠倒 按照 lvha 的顺序。 love hate 爱上了讨厌 记忆法 或者 lv 包包 非常 hao

a {   /* a是标签选择器  所有的链接 */
            font-weight: 700;
            font-size: 16px;
            color: gray;
        }
a:hover {   /* :hover 是链接伪类选择器 鼠标经过 */
            color: red; /*  鼠标经过的时候,由原来的 灰色 变成了红色 */
}

十一、sublime快捷方式

sublime可以快速提高我们代码的书写方式

  1. 生成标签 直接输入标签名 按tab键即可 比如 div 然后tab 键, 就可以生成 <div></div>

  2. 如果想要生成多个相同标签 加上 * 就可以了 比如 div*3 就可以快速生成3个div

  3. 如果有父子级关系的标签,可以用 > 比如 ul > li就可以了

  4. 如果有兄弟关系的标签,用 + 就可以了 比如 div+p

  5. 如果生成带有类名或者id名字的, 直接写 .demo 或者 #two tab 键就可以了

十二、标签显示模式(display)

12.1 块级元素(block-level)

  每个块元素通常都会独自占据一整行或多整行,可以对其设置宽度、高度、对齐等属性,常用于网页布局和网页结构的搭建。

常见的块元素有<h1>~<h6><p><div><ul><ol><li>等,其中<div>标签是最典型的块元素。

  div非常符合布局,所以多喜欢叫 css + div 布局

块级元素的特点:

(1)总是从新行开始
(2)高度,行高、外边距以及内边距都可以控制。
(3)宽度默认是容器的100%
(4)可以容纳内联元素和其他块元素。

12.2 行内元素(inline-level)

  行内元素(内联元素)不占有独立的区域,仅仅靠自身的字体大小和图像尺寸来支撑结构,一般不可以设置宽度、高度、对齐等属性,常用于控制页面中文本的样式。

常见的行内元素有<a><strong><b><em><i><del><s><ins><u><span>等,其中<span>标签最典型的行内元素。

行内元素的特点:

(1)和相邻行内元素在一行上。
(2)高、宽无效,但水平方向的padding和margin可以设置,垂直方向的无效。
(3)默认宽度就是它本身内容的宽度。
(4)行内元素只能容纳文本或则其他行内元素。(a特殊,a里面可以放块级元素

注意:

  1. 只有 文字才 能组成段落 因此 p 里面不能放块级元素,同理还有这些标签h1,h2,h3,h4,h5,h6,dt,他们都是文字类块级标签,里面不能放其他块级元素。

  2. 链接里面不能再放链接。


12.3 块级元素和行内元素区别

块级元素的特点:
(1)总是从新行开始
(2)高度,行高、外边距以及内边距都可以控制。
(3)宽度默认是容器的100%
(4)可以容纳内联元素和其他块元素。

行内元素的特点:
(1)和相邻行内元素在一行上。
(2)高、宽无效,但水平方向的padding和margin可以设置,垂直方向的无效。
(3)默认宽度就是它本身内容的宽度。
(4)行内元素只能容纳文本或则其他行内元素。

12.4 行内块元素(inline-block)

在行内元素中有几个特殊的标签——<img />、<input />、<td>,可以对它们设置宽高和对齐属性,有些资料可能会称它们为行内块元素。

行内块元素的特点:

(1)和相邻行内元素(行内块)在一行上,但是之间会有空白缝隙。
(2)默认宽度就是它本身内容的宽度。
(3)高度,行高、外边距以及内边距都可以控制

12.5 标签显示模式转换 display

块转行内:display:inline;
行内转块:display:block;
块、行内元素转换为行内块: display: inline-block;
此阶段,我们只需关心这三个,其他的是我们后面的工作。

十三、CSS书写规范

13.1 空格规范

【强制】 选择器 与 { 之间必须包含空格。

.selector { }

【强制】 属性名 与之后的 : 之间不允许包含空格, : 与 属性值 之间必须包含空格。

font-size: 12px;

13.2 选择器规范

【强制】 当一个 rule 包含多个 selector 时,每个选择器声明必须独占一行。

/* good */
.post,
.page,
.comment {
    line-height: 1.5;
}
​
​
/* bad */
.post, .page, .comment {
    line-height: 1.5;
}

【建议】 选择器的嵌套层级应不大于 3 级,位置靠后的限定条件应尽可能精确。

/* good */
#username input {}
.comment .avatar {}
​
/* bad */
.page .header .login #username input {}
.comment div * {}

13.3 属性规范

【强制】 属性定义必须另起一行。

/* good */
.selector {
    margin: 0;
    padding: 0;
}
​
/* bad */
.selector { margin: 0; padding: 0; }

【强制】 属性定义后必须以分号结尾。

/* good */
.selector {
    margin: 0;
}
​
/* bad */
.selector {
    margin: 0
}

十四、行高的问题

行高我们利用最多的一个地方是:可以让一行文本在盒子中垂直居中对齐。

做法就是:文字的行高等于盒子的高度。

上距离和下距离总是相等的,因此文字看上去是垂直居中的。如果 行高 等于 height 高度,文字会垂直居中。如果行高大于高度,文字会偏下。如果行高小于高度,文字会偏上。

练习

测试题
三种显示模式 (inline  block inline-block)
1元素有哪几种显示方式(A(A) block inline inline-block (B) block none inline-block (C) none inline inline-block (D) block inline none
2关于显示方式说法不正确的是 (D) (A) 块级元素独占一行, (B) 行内元素一行可以放多个 (C) 块级可以容纳行内元素 (D) 块级元素的代表有div h p img 等;
3关于显示方式说法正确的是 (C) (A) 只有行内元素一行可以放多个 (B) 所有的元素宽高都由内容决定 (C) 行内元素只能容纳文本或其他行内元素 (D) 行内元素的代表有span a img 等;
4给DIV设置什么属性可以 让一个div的显示方式与span标签一样的 (B) (A) display: block (B) display: inline (C) display: inline-block (D) display:none;
5下面哪个标签默认情况下不能再同一行显示(A) (A) p (B) span (C)a (D) img 交集并集后代 子代元素选择器 1选择器#box p,下列说法中正确的是(B) (A) 选择的是id为box的元素的所有直接子元素p (B) 选择的是id为box的元素的所有后代元素p (C) 选择的是id为box的元素的第一个子元素p (D) 选择的是id为box的元素的第一个后代元素p
2选择器#box>p,下列说法中正确的是(A) (A) 选择的是id为box的元素的所有直接子元素p (B) 选择的是id为box的元素的所有后代元素p (C) 选择的是id为box的元素的直接子元素p (D) 选择的是id为box的元素和p元素 3选择器p, .box,下列说法中正确的是(B) (A) 选择的是p元素 后代里所有类名为box的元素 (B) 选择的是p元素 和所有类名为box的元素 (C) 选择的是p元素后代里第一个类名为box的子元素 (D) 选择的是拥有box类名的p元素
4选择器p.box,下列说法中正确的是(D)
(A) 选择的是p元素 后代里所有类名为box的元素 (B) 选择的是p元素 和所有类名为box的元素 (C) 选择的是p元素后代里第一个类名为box的子元素 (D) 选择的是拥有box类名的p元素

十五、CSS 三大特性

  层叠 继承 优先级 是我们学习CSS 必须掌握的三个特性。

15.1 CSS层叠性

  所谓层叠性是指多种CSS样式的叠加。

  是浏览器处理冲突的一个能力,如果一个属性通过两个相同选择器设置到同一个元素上,那么这个时候一个属性就会将另一个属性层叠掉

  比如先给某个标签指定了内部文字颜色为红色,接着又指定了颜色为蓝色,此时出现一个标签指定了相同样式不同值的情况,这就是样式冲突。

  一般情况下,如果出现样式冲突,则会按照CSS书写的顺序,以最后的样式为准

样式冲突,遵循的原则是就近原则。 那个样式离着结构近,就执行那个样式。

样式不冲突不会层叠

15.2 CSS继承性

  所谓继承性是指书写CSS样式表时,子标签会继承父标签的某些样式(不是全部,比如盒子的高度就不继承),如文本颜色和字号。想要设置一个可继承的属性,只需将它应用于父元素即可。

  简单的理解就是: 子承父业。

 注意:

恰当地使用继承可以简化代码,降低CSS样式的复杂性。子元素可以继承父元素的样式(text-,font-,line-这些元素开头的都可以继承,以及color属性)

15.3 CSS优先级

定义CSS样式时,经常出现两个或更多规则应用在同一元素上,这时就会出现优先级的问题。

在考虑权重时,初学者还需要注意一些特殊的情况,具体如下:

继承样式的权重为0。即在嵌套结构中,不管父元素样式的权重多大,被子元素继承时,他的权重都为0,也就是说子元素定义的样式会覆盖继承来的样式。
​
行内样式优先。应用style属性的元素,其行内样式的权重非常高,可以理解为远大于100。总之,他拥有比上面提高的选择器都大的优先级。
​
权重相同时,CSS遵循就近原则。也就是说靠近元素的样式具有最大的优先级,或者说排在最后的样式优先级最大。
​
CSS定义了一个!important命令,该命令被赋予最大的优先级。也就是说不管权重如何以及样式位置的远近,!important都具有最大优先级。

15.4 CSS特殊性(Specificity)

关于CSS权重,我们需要一套计算公式来去计算,这个就是 CSS Specificity,我们称为CSS 特性或称非凡性,它是一个衡量CSS值优先级的一个标准 具体规范入如下:

specificity用一个四位的数 字串(CSS2是三位)来表示,更像四个级别,值从左到右,左面的最大,一级大于一级,数位之间没有进制,级别之间不可超越。

继承或者* 的贡献值0,0,0,0
每个元素(标签)贡献值为 0,0,0,1
每个类,伪类贡献值为 0,0,1,0
每个ID贡献值为 0,1,0,0
每个行内样式贡献值 1,0,0,0
每个!important贡献值 ∞ 无穷大

 

权重是可以叠加的

比如的例子:

div ul  li   ------>      0,0,0,3
.nav ul li   ------>      0,0,1,2
a:hover      -----—>      0,0,1,1
.nav a       ------>      0,0,1,1   
#nav p       ----->       0,1,0,1

div {
  color: hotpink!important;
}

练习

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "
http://www.w3.org/TR/html4/loose.dtd">
<html>
    <head>
        <meta http-equiv="content-type" content="text/html;charset=utf-8" />
        <meta name="keywords" content="关键词1,关键词2,关键词3" />
        <meta name="description" content="对网站的描述" />
        <title>第1题</title>
        <style type="text/css">
            #father #son{  
                color:blue;
            }
            #father p.c2{
                color:black;
            }
            div.c1 p.c2{
                color:red;
            }
            #father{
                color:green !important;  /* 继承的权重为0 */
            }
        </style>
    </head>
    <body>
        <div id="father" class="c1">
            <p id="son" class="c2">
                试问这行字体是什么颜色的?
            </p>
        </div>
    </body>
</html>
练习一
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "
http://www.w3.org/TR/html4/loose.dtd">
<html>
    <head>
        <meta http-equiv="content-type" content="text/html;charset=utf-8" />
        <meta name="keywords" content="关键词1,关键词2,关键词3" />
        <meta name="description" content="对网站的描述" />
        <title>第2题</title>
        <style type="text/css">
            #father{
                color:red;/* 继承的权重为0 */
            }
            p{
                color:blue;  
            }
        </style>
    </head>
    <body>
        <div id="father">
            <p>试问这行字体是什么颜色的?</p>
        </div>
    </body>
</html>
练习二
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "
http://www.w3.org/TR/html4/loose.dtd">
<html>
    <head>
        <meta http-equiv="content-type" content="text/html;charset=utf-8" />
        <meta name="keywords" content="关键词1,关键词2,关键词3" />
        <meta name="description" content="对网站的描述" />
        <title>第3题</title>
        <style type="text/css">
            div p{   
                color:red;
            }
            #father{
                color:red;
            }
            p.c2{    
                color:blue;
            }
        </style>
    </head>
    <body>
        <div id="father" class="c1">
            <p class="c2">
                试问这行字体是什么颜色的?
            </p>
        </div>
    </body>
</html>
练习三
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "
http://www.w3.org/TR/html4/loose.dtd">
<html>
    <head>
        <meta http-equiv="content-type" content="text/html;charset=utf-8" />
        <meta name="keywords" content="关键词1,关键词2,关键词3" />
        <meta name="description" content="对网站的描述" />
        <title>第4题</title>
        <style type="text/css">
            div div{ 
                color:blue;
            }
            div{
                color:red;
            }
        </style>
    </head>
    <body>
        <div>
            <div>
                <div>
                    试问这行字体是什么颜色的?
                </div>
            </div>
        </div>
    </body>
</html>
练习四
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
    <title>Document</title>
    <style type="text/css">
        div div div div div div div div div div div div{  
            color:red;
        }
        .me{ 
            color:blue;
        }
    </style>
</head>
<body>
    <div>
        <div>
            <div>
                <div>
                    <div>
                        <div>
                            <div>
                                <div>
                                    <div>
                                        <div>
                                            <div>
                                                <div class="me">试问这行文字是什么颜色的</div>
                                            </div>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                    </div>
                </div>
            </div>
        </div>
    </div>
</body>
</html>
练习五
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
    <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
    <title>Document</title>
    <style type="text/css">
        .c1 .c2 div{  
            color: blue;
        }
        div #box3{
            color:green;
        }
        #box1 div{
            color:yellow;
        }
    </style>
</head>
<body>
    <div id="box1" class="c1">
        <div id="box2" class="c2">
            <div id="box3" class="c3">
                文字
            </div>
        </div>
    </div>
</body>
</html>
练习六

注意

1.数位之间没有进制 比如说: 0,0,0,5 + 0,0,0,5 =0,0,0,10 而不是 0,0, 1, 0, 所以不会存在10个div能赶上一个类选择器的情况。

2.继承的 权重是 0

总结优先级

  1. 使用了 !important声明的规则。

  2. 内嵌在 HTML 元素的 style属性里面的声明。

  3. 使用了 ID 选择器的规则。

  4. 使用了类选择器、属性选择器、伪元素和伪类选择器的规则。

  5. 使用了元素选择器的规则。

  6. 只包含一个通用选择器的规则。

  7. 同一类选择器则遵循就近原则。

总结:权重是优先级的算法,层叠是优先级的表现

十六、CSS 背景(background)

  CSS 可以添加背景颜色和背景图片,以及来进行图片设置。

background-color背景颜色
background-image 背景图片地址
background-repeat 是否平铺
background-position 背景位置
background-attachment 背景固定还是滚动
背景的合写(复合属性)  
background:背景颜色 背景图片地址 背景平铺 背景滚动 背景位置  

16.1 背景图片(image)

语法:

background-image : none | url (url) 

参数:

none :  无背景图(默认的) url :  使用绝对或相对地址指定背景图像

background-image 属性允许指定一个图片展示在背景中(只有CSS3才可以多背景)可以和 background-color 连用。 如果图片不重复地话,图片覆盖不到地地方都会被背景色填充。 如果有背景图片平铺,则会覆盖背景颜色。

小技巧: 我们提倡 背景图片后面的地址,url不要加引号。

16.2 背景平铺(repeat)

语法:

background-repeat : repeat | no-repeat | repeat-x | repeat-y 

参数:

repeat :  背景图像在纵向和横向上平铺(默认的)

no-repeat :  背景图像不平铺

repeat-x :  背景图像在横向上平铺

repeat-y :  背景图像在纵向平铺

设置背景图片时,默认把图片在水平和垂直方向平铺以铺满整个元素。

repeat-x :  背景图像在横向上平铺

repeat-y :  背景图像在纵向平铺

16.3 背景位置(position)

语法:

background-position : length || length
​
background-position : position || position 

参数:

length :  百分数 | 由浮点数字和单位标识符组成的长度值。请参阅长度单位 position :  top | center | bottom | left | center | right

说明:

  设置或检索对象的背景图像位置。必须先指定background-image属性。默认值为:(0% 0%)。 如果只指定了一个值,该值将用于横坐标。纵坐标将默认为50%。第二个值将用于纵坐标。

注意:

  1. position 后面是x坐标和y坐标。 可以使用方位名词(没有上下顺序)或者 精确单位(有顺序,x在前,y在后)。

  2. 如果和精确单位和方位名字混合使用,则必须是x坐标在前,y坐标后面。比如 background-position: 15px top; 则 15px 一定是 x坐标 top是 y坐标。

  3. 如果position只写一个值,另外一个默认是居中的。 

16.4 背景附着

语法:

background-attachment : scroll | fixed 

参数:

  scroll :  背景图像是随对象内容滚动

  fixed :  背景图像固定

说明:

  设置或检索背景图像是随对象内容滚动还是固定的。

16.5 背景简写

  ackground属性的值的书写顺序官方并没有强制标准的。为了可读性,建议大家如下写:

  background:背景颜色 背景图片地址 背景平铺 背景滚动 背景位置

background: transparent url(image.jpg) repeat-y  scroll 50% 0 ;

16.6 背景透明(CSS3)

  CSS3支持背景半透明的写法语法格式是:

background: rgba(0,0,0,0.3);

  最后一个参数是alpha 透明度 取值范围 0~1之间

  注意: 背景半透明是指盒子背景半透明, 盒子里面的内容不受影响。

十七、盒子模型(CSS重点)

  其实,CSS就三个大模块: 盒子模型 、 浮动 、 定位,其余的都是细节。要求这三部分,无论如何也要学的非常精通。

  所谓盒子模型就是把HTML页面中的元素看作是一个矩形的盒子,也就是一个盛装内容的容器。每个矩形都由元素的内容、内边距(padding)、边框(border)和外边距(margin)组成。

  看透网页布局的本质: 把网页元素比如文字图片等等,放入盒子里面,然后利用CSS摆放盒子的过程,就是网页布局。

17.1 盒子模型(Box Model)

  这里略过 老旧的ie盒子模型(IE6以下),对不起,我都没见过IE5的浏览器。

  所有的文档元素(标签)都会生成一个矩形框,我们成为元素框(element box),它描述了一个文档元素再网页布局汇总所占的位置大小。因此,每个盒子除了有自己大小和位置外,还影响着其他盒子的大小和位置。

17.2 盒子边框(border)

border : border-width || border-style || border-color 

  边框属性—设置边框样式(border-style)

  边框样式用于定义页面中边框的风格,常用属性值如下:

none:没有边框即忽略所有边框的宽度(默认值)

solid:边框为单实线(最为常用的)

dashed:边框为虚线  

dotted:边框为点线

double:边框为双实线

17.2.1 盒子边框写法总结表

设置内容 样式属性 常用属性值
上边框 border-top-style:样式; border-top-宽度;border-top-color:颜色;border-top:宽度 样式 颜色;  
下边框 border-bottom-style:样式;border- bottom-宽度;border- bottom-color:颜色;border-bottom:宽度 样式 颜色;  
左边框 border-left-style:样式; border-left-宽度;border-left-color:颜色;border-left:宽度 样式 颜色;  
右边框 border-right-style:样式;border-right-宽度;border-right-color:颜色;border-right:宽度 样式 颜色;  
样式综合设置 border-style:上边 [右边 下边 左边]; none无(默认)、solid单实线、dashed虚线、dotted点线、double双实线
宽度综合设置 border-上边 [右边 下边 左边]; 像素值
颜色综合设置 border-color:上边 [右边 下边 左边]; 颜色值、#十六进制、rgb(r,g,b)、rgb(r%,g%,b%)
边框综合设置 border:四边宽度 四边样式 四边颜色;  
div {
    border-top: 1px solid red;
    border-bottom: 2px solid green;
    border-left: 2px solid green;
    border-right: 2px solid green;
    border: 1px solid blue;
}

17.2.2 表格的细线边框

table, td {
border-collapse: collapse;
}

border-collapse:collapse; 表示边框合并在一起。

17.2.3 圆角边框(CSS3)

  从此以后,我们的世界不只有矩形。radius 半径(距离)

  语法格式:

border-radius: 左上角  右上角  右下角  左下角;
border-radius: 50%;

17.3 内边距(padding)

  padding属性用于设置内边距。 是指 边框与内容之间的距离。padding会撑开带有 width 和 height 盒子

padding-top:上内边距
padding-right:右内边距
padding-bottom:下内边距
padding-left:左内边距

注意: 后面跟几个数值表示的意思是不一样的。

值的个数表达意思
1个值 padding:上下左右边距 比如padding: 3px; 表示上下左右都是3像素
2个值 padding: 上下边距 左右边距 比如 padding: 3px 5px; 表示 上下3像素 左右 5像素
3个值 padding:上边距 左右边距 下边距 比如 padding: 3px 5px 10px; 表示 上是3像素 左右是5像素 下是10像素
4个值 padding:上内边距 右内边距 下内边距 左内边距 比如: padding: 3px 5px 10px 15px; 表示 上3px 右是5px 下 10px 左15px 顺时针

练习

  要两个盒子,中间的盒子100*100,外面的盒子300*300

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
    .father {
        width: 180px;
        height: 180px;
        background-color: pink;
        padding-left: 100px;
        padding-top: 100px;
        border: 10px solid red;
    }
    .son {
        width: 100px;
        height: 100px;
        background-color: purple;
    }
    </style>
</head>
<body>
    <div class="father">
        <div class="son"></div>
    </div>
</body>
</html>

清楚内外边距

* {
    margin:0;
    padding: 0;  
}

清除 列表前面的点

li {
    list-style: none;
}

17.4 外边距(margin)

  margin属性用于设置外边距。 设置外边距会在元素之间创建“空白”, 这段空白通常不能放置其他内容。

margin-top:上外边距

margin-right:右外边距

margin-bottom:下外边距

margin-left:上外边距

margin:上外边距 右外边距 下外边距 左外边

  取值顺序跟内边距相同。

17.4.1 外边距实现盒子居中

  可以让一个盒子实现水平居中,需要满足一下两个条件:

  1. 必须是块级元素。

  2. 盒子必须指定了宽度(width)

  然后就给左右的外边距都设置为auto,就可使块级元素水平居中。

  实际工作中常用这种方式进行网页布局,示例代码如下:

.header { 
  width:960px; 
  margin:0 auto;   
}

margin-left:auto;则左边自动充满。所以
margin:0 auto等同于
margin-left:auto;
margin-right:auto;

还可以
margin: auto; 上下auto不解析,所以也可以。

17.4.2 文字盒子居中图片和背景区别

  1. 文字水平居中是 text-align: center

  2. 盒子水平居中 左右margin 改为 auto

text-align: center; /*  文字居中水平 */
margin: 10px auto;  /* 盒子水平居中  左右margin 改为 auto 就阔以了 */
  1. 插入图片 我们用的最多 比如产品展示类

  2. 背景图片 我们一般用于小图标背景 或者 超大背景图片(logo,小图标等)

section img {  
        width: 200px;/* 插入图片更改大小 width 和 height */
        height: 210px;
        margin-top: 30px;  /* 插入图片更改位置 可以用margin 或padding  盒模型 */
        margin-left: 50px; /* 插入当图片也是一个盒子 */
    }

aside {
        width: 400px;
        height: 400px;
        border: 1px solid purple;
        background: #fff url(images/sun.jpg) no-repeat;
    
        background-size: 200px 210px; /*  背景图片更改大小只能用 background-size */
        background-position: 30px 50px; /* 背景图片更该位置 我用 background-position */
    }

17.4.3 清除元素的默认内外边距

  为了更方便地控制网页中的元素,制作网页时,可使用如下代码清除元素的默认内外边距:

* {
   padding:0;         /* 清除内边距 */
   margin:0;          /* 清除外边距 */
}

  注意: 行内元素是只有左右外边距的,是没有上下外边距的。 内边距,在ie6等低版本浏览器也会有问题。

  我们尽量不要给行内元素指定上下的内外边距就好了。

17.5 外边距合并

  使用margin定义块元素的垂直外边距时,可能会出现外边距的合并。

17.5.1 相邻块元素垂直外边距的合并

  当上下相邻的两个块元素相遇时,如果上面的元素有下外边距margin-bottom,下面的元素有上外边距margin-top,则他们之间的垂直间距不是margin-bottom与margin-top之和,而是两者中的较大者。这种现象被称为相邻块元素垂直外边距的合并(也称外边距塌陷)。

  解决方案: 避免就好了。

17.5.2 嵌套块元素垂直外边距的合并

  对于两个嵌套关系的块元素,如果父元素没有上内边距及边框,则父元素的上外边距会与子元素的上外边距发生合并,合并后的外边距为两者中的较大者,即使父元素的上外边距为0,也会发生合并。

 

解决方案:

  1. 可以为父元素定义1像素的上边框或上内边距。

  2. 可以为父元素添加overflow:hidden。

待续。。。。

17.6 content宽度和高度

  使用宽度属性 width 和高度属性 height 可以对盒子的大小进行控制。

  width 和 height 的属性值可以为不同单位的数值或相对于父元素的百分比%,实际工作中最常用的是像素值。

  大多数浏览器,如Firefox、IE6及以上版本都采用了W3C规范,符合CSS规范的盒子模型的总宽度和总高度的计算原则是:

  /*外盒尺寸计算(元素空间尺寸)*/
  Element空间高度 = content height + padding + border + margin
  Element 空间宽度 = content width + padding + border + margin
  /*内盒尺寸计算(元素实际大小)*/
  Element Height = content height + padding + border (Height为内容高度)
  Element Width = content width + padding + border (Width为内容宽度)

注意:

  1. 宽度属性width和高度属性height仅适用于块级元素,对行内元素无效( img 标签和 input除外)。
  2. 计算盒子模型的总高度时,还应考虑上下两个盒子垂直外边距合并的情况。
  3. 如果一个盒子没有给定宽度,则直接 占满父盒子宽度。且如果一个盒子没有指定宽度或者是继承了父盒子宽度,则padding 不会影响本盒子大小

17.7 盒子模型布局稳定性

  开始学习盒子模型,同学们最大的困惑就是, 分不清内外边距的使用,什么情况下使用内边距,什么情况下使用外边距?

  答案是: 其实他们大部分情况下是可以混用的。 就是说,你用内边距也可以,用外边距也可以。 你觉得哪个方便,就用哪个。

  但是,总有一个最好用的吧,我们根据稳定性来分,建议如下:

  按照 优先使用 宽度 (width) 其次 使用内边距(padding) 再次 外边距(margin)。

width >  padding  >   margin  

原因:

  1. margin 会有外边距合并 还有 ie6下面margin 加倍的bug(讨厌)所以最后使用。

  2. padding 会影响盒子大小, 需要进行加减计算(麻烦) 其次使用。

  3. width 没有问题(嗨皮)我们经常使用宽度剩余法 高度剩余法来做。

17.8 盒子阴影

语法格式:

box-shadow:水平阴影 垂直阴影 模糊距离(虚实) 阴影尺寸(影子大小) 阴影颜色  内/外阴影;

  1. 前两个属性是必须写的。其余的可以省略。

  2. 外阴影 (outset) 但是不能写 默认 想要内阴影 inset

div {
            width: 200px;
            height: 200px;
            border: 10px solid red;
            /* box-shadow: 5px 5px 3px 4px rgba(0, 0, 0, .4);  */
            /* box-shadow:水平位置 垂直位置 模糊距离 阴影尺寸(影子大小) 阴影颜色  内/外阴影; */
            box-shadow: 0 10px 20px rgba(0,0,0,0.1);(小米的)
      transition: all .5s; 阴影渐渐出来
             0 15px 30px rgba(0,0,0,0.1);小米的第二种写法
}

  中间的是width和height,绿色为padding,橘色为margin

十八、浮动(float)

18.1 普通流(normal flow)

  这个单词很多人翻译为 文档流 , 字面翻译 普通流 或者标准流都可以。

  前面我们说过,网页布局的核心,就是用CSS来摆放盒子位置。如何把盒子摆放到合适的位置?

  CSS的定位机制有3种:普通流(标准流)、浮动和定位。

  html语言当中另外一个相当重要的概念----------标准流!或者普通流。普通流实际上就是一个网页内标签元素正常从上到下,从左到右排列顺序的意思,比如块级元素会独占一行,行内元素会按顺序依次前后排列;按照这种大前提的布局排列之下绝对不会出现例外的情况叫做普通流布局。

 

18.2 浮动(float)

  浮动最早是用来控制图片,以便达到其他元素(特别是文字)实现“环绕”图片的效果。

  

  后来,我们发现浮动有个很有意思的事情:就是让任何盒子可以一行排列,因此我们就慢慢的偏离主题,用浮动的特性来布局了。(CSS3已经我们真正意义上的网页布局,具体CSS3我们会详细解释)

 

18.3 什么是浮动?

  元素的浮动是指设置了浮动属性的元素会脱离标准普通流的控制,移动到其父元素中指定位置的过程。

  在CSS中,通过float属性来定义浮动,其基本语法格式如下:

选择器{float:属性值;}
属性值描述
left 元素向左浮动
right 元素向右浮动
none 元素不浮动(默认值)

18.4 浮动详细内幕特性

  浮动脱离标准流,不占位置,会影响标准流。浮动只有左右浮动

浮动首先创建包含块的概念(包裹)。就是说, 浮动的元素总是找理它最近的父级元素对齐。但是不会超出内边距的范围。 

浮动的元素排列位置,跟上一个元素(块级)有关系。如果上一个元素有浮动,则A元素顶部会和上一个元素的顶部对齐;如果上一个元素是标准流,则A元素的顶部会和上一个元素的底部对齐。

由2可以推断出,一个父盒子里面的子盒子,如果其中一个子级有浮动的,则其他子级都需要浮动。这样才能一行对齐显示。
元素添加浮动后,元素会具有行内块元素浮动可以让元素默认转换为行内块元素)的特性。
妙用:如果已经给行内元素添加了浮动,此时不需要转换,这个元素也可以有宽高。
元素的大小完全取决于定义的大小或者默认的内容多少浮动根据元素书写的位置来显示相应的浮动。

  总结: 浮动 --->

  浮动的目的就是为了让多个块级元素同一行上显示。

  float 浮 漏 特

  浮: 加了浮动的元素盒子是浮起来的,漂浮在其他的标准流盒子上面。

  漏: 加了浮动的盒子,不占位置的,它浮起来了,它原来的位置漏 给了标准流的盒子。

  特: 特别注意,首先浮动的盒子需要和标准流的父级搭配使用, 其次 特别的注意浮动可以使元素显示模式体现为行内块特性。

十九、版心和布局流程

  阅读报纸时容易发现,虽然报纸中的内容很多,但是经过合理地排版,版面依然清晰、易读。同样,在制作网页时,要想使页面结构清晰、有条理,也需要对网页进行“排版”。

  “版心”(可视区) 是指网页中主体内容所在的区域。一般在浏览器窗口中水平居中显示,常见的宽度值为960px、980px、1000px、1200px等。

19.1 布局流程

为了提高网页制作的效率,布局时通常需要遵守一定的布局流程,具体如下:

1、确定页面的版心(可视区)。

2、分析页面中的行模块,以及每个行模块中的列模块。

3、制作HTML结构 。

4、CSS初始化,然后开始运用盒子模型的原理,通过DIV+CSS布局来控制网页的各个模块。

19.2 一列固定宽度且居中

最普通的,最为常用的结构

19.2 两列左窄右宽型

比如小米  小米官网 

19.3 通栏平均分布型

二十、清除浮动

PS:

ctrl + r 显示隐藏标尺,右击标尺---把里面的单位一律改成像素

ctrl + d 取消

切片切好,文件-》导出》web格式

选中图层-》新建基于图层的切片

 

 

原文地址:https://www.cnblogs.com/dongye95/p/10581307.html