CSS

 

css概述

CSS是Cascading Style Sheets的简称,中文称为层叠样式表,用来控制网页数据的表现,可以使网页的表现与数据内容分离。

一 css的四种引入方式

1.行内式
          行内式是在标记的style属性中设定CSS样式。这种方式没有体现出CSS的优势,不推荐使用

<p style="background-color: rebeccapurple">hello yuan</p>

2.嵌入式
          嵌入式是将CSS样式集中写在网页的<head></head>标签对的<style></style>标签对中。格式如下:

1
2
3
4
5
6
7
8
9
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        p{
            background-color: #2b99ff;
        }
    </style>
</head>

3 链接式
            将一个.css文件引入到HTML文件中

1
<link href="mystyle.css" rel="stylesheet" type="text/css"/>

4.导入式
          将一个独立的.css文件引入HTML文件中,导入式使用CSS规则引入外部CSS文件,<style>标记也是写在<head>标记中,使用的语法如下:    

1
2
3
4
5
<style type="text/css">
 
          @import"mystyle.css"; 此处要注意.css文件的路径
 
</style> 

注意:

      导入式会在整个网页装载完后再装载CSS文件,因此这就导致了一个问题,如果网页比较大则会儿出现先显示无样式的页面,闪烁一下之后,再出现网页的样式。这是导入式固有的一个缺陷。使用链接式时与导入式不同的是它会以网页文件主体装载前装载CSS文件,因此显示出来的网页从一开始就是带样式的效果的,它不会象导入式那样先显示无样式的网页,然后再显示有样式的网页,这是链接式的优点。

二 css的选择器(Selector)

“选择器”指明了{}中的“样式”的作用对象,也就是“样式”作用于网页中的哪些元素

1 基础选择器

* :           通用元素选择器,匹配任何元素                    * { margin:0; padding:0; }

E  :          标签选择器,匹配所有使用E标签的元素               p { color:green; }

.info和E.info: class选择器,匹配所有class属性中包含info的元素   .info { background:#ff0; }    p.info { background:blue; }

#info和E#info  id选择器,匹配所有id属性等于footer的元素         #info { background:#ff0; }   p#info { background:#ff0; }

2 组合选择器

 E,F         多元素选择器,同时匹配所有E元素或F元素,E和F之间用逗号分隔         div,p { color:#f00; }

 E F         后代元素选择器,匹配所有属于E元素后代的F元素,E和F之间用空格分隔    li a { font-weight:bold;
 E > F       子元素选择器,匹配所有E元素的子元素F                            div > p { color:#f00; }
 
E + F       毗邻元素选择器,匹配所有紧随E元素之后的同级元素F                  div + p { color:#f00; }  
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7 
 8         .div1>p{
 9             background-color: aqua;
10             color: deeppink;
11         }
12 
13         .main2>div{
14             background-color: blueviolet;
15             color: chartreuse;
16         }
17     </style>
18 </head>
19 <body>
20 
21       <div class="div1">hello1
22           <div class="div2">hello2
23               <div>hello4</div>
24               <p>hello5</p>
25           </div>
26           <p>hello3</p>
27       </div>
28       <p>hello6</p>
29 
30 <hr>
31 
32      <div class="main2">1
33        <div>2
34            <div>
35            </div>
36        </div>
37        <div>
38            </div>
39      </div>
40 </body>
41 </html>
View Code
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title></title>
 6     <style>
 7         /*div{
 8             font-size: 30px;
 9         }
10         .active{
11             color: green;
12         }
13         div.active{
14             text-decoration: underline;
15         }*/
16         div{
17             color: red;
18         }
19         div.active{
20             color: green;
21         }
22     </style>
23 
24 </head>
25 <body>
26     <div class="active">alex</div>
27     
28 </body>
29 </html>
交集选择器
 1 /*选中第一个元素*/
 2         div ul li:first-child{
 3             font-size: 20px;
 4             color: red;
 5         }
 6         /*选中最后一个元素*/
 7         div ul li:last-child{
 8             font-size: 20px;
 9             color: yellow;
10         }
11         
12         /*选中当前指定的元素  数值从1开始*/
13         div ul li:nth-child(3){
14             font-size: 30px;
15             color: purple;
16         }
17         
18         /*n表示选中所有,这里面必须是n, 从0开始的  0的时候表示没有选中*/
19         div ul li:nth-child(n){
20             font-size: 40px;
21             color: red;
22         }
23         
24         /*偶数*/
25         div ul li:nth-child(2n){
26             font-size: 50px;
27             color: gold;
28         }
29         /*奇数*/
30         div ul li:nth-child(2n-1){
31             font-size: 50px;
32             color: yellow;
33         }
34         /*隔几换色  隔行换色
35              隔4换色 就是5n+1,隔3换色就是4n+1
36             */
37         
38         div ul li:nth-child(5n+1){
39             font-size: 50px;
40             color: red;
41         }
css3的选择器nth-child()
 1 /*设置第一个首字母的样式*/
 2         p:first-letter{
 3             color: red;
 4             font-size: 30px;
 5 
 6         }
 7         
 8 /* 在....之前 添加内容   这个属性使用不是很频繁 了解  使用此伪元素选择器一定要结合content属性*/
 9         p:before{
10             content:'alex';
11         }
12         
13         
14 /*在....之后 添加内容,使用非常频繁 通常与咱们后面要讲到布局 有很大的关联(清除浮动)*/
15         p:after{
16             content:'&';
17             color: red;
18             font-size: 40px;
19         }
伪元素选择器

 

注意嵌套规则

  1. 块级元素可以包含内联元素或某些块级元素,但内联元素不能包含块级元素,它只能包含其它内联元素。
  2. 有几个特殊的块级元素只能包含内联元素,不能包含块级元素。如h1,h2,h3,h4,h5,h6,p,dt
  3. li内可以包含div
  4. 块级元素与块级元素并列、内联元素与内联元素并列。
     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>Title</title>
     6     <style>
     7         [suoning]{
     8             color: blueviolet;
     9         }
    10         .he>div{
    11             color: bisque;
    12         }
    13 
    14     </style>
    15 </head>
    16 <body>
    17 
    18 <div class="he">111
    19     <p class="fr">222
    20         <div>333</div>
    21     </p>
    22     <div>444</div>
    23 </div>
    24 
    25 
    26 ***************************
    27 
    28 <div suoning="sb">ddd
    29          <p>pppp</p>
    30      </div>
    31      <p suoning="sb2">ddd2
    32          <p>pppp2</p>
    33      </p>
    34 </body>
    35 </html>
    View Code

3 属性选择器

 E[att]         匹配所有具有att属性的E元素,不考虑它的值。(注意:E在此处可以省略,比如“[cheacked]”。以下同。)   p[title] { color:#f00; }

 
 E[att=val]     匹配所有att属性等于“val”的E元素                                 div[class=”error”] { color:#f00; }

 
 E[att~=val]    匹配所有att属性具有多个空格分隔的值、其中一个值等于“val”的E元素      td[class~=”name”] { color:#f00; }

 E[attr^=val]    匹配属性值以指定值开头的每个元素                     div[class^="test"]{background:#ffff00;}

 E[attr$=val]    匹配属性值以指定值结尾的每个元素                     div[class$="test"]{background:#ffff00;}

 E[attr*=val]    匹配属性值中包含指定值的每个元素                     div[class*="test"]{background:#ffff00;}

4 伪类(Pseudo-classes)

CSS伪类是用来给选择器添加一些特殊效果。

伪类选择器的顺序:link(正常状态) > visited(访问过后的状态) > hover(鼠标放上去的状态) > active(鼠标按下并未抬起的状态)

hover:

        当鼠标放在c1上时,c1下的c2才生效
       .c1:hover .c2{
        }

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         .left{
 8             float: left;
 9         }
10         .clearfix:after{
11             content: '.';
12             display: block;
13             clear: both;
14             visibility: hidden;
15             height: 0;
16         }
17         .container{
18             background-color: red;
19         }
20         .container .item{
21             width: 180px;
22             height: 150px;
23             background-color: #303a40;
24             border: 1px solid red;
25             overflow: hidden;
26             position: relative;
27         }
28         .hide{
29             display: none;
30         }
31         .container .item:hover{
32             border: 1px solid green;
33         }
34         .container .item .text{
35             display: none;
36         }
37         .container .item:hover .text{
38             display: block;
39         }
40     </style>
41 </head>
42 <body>
43     <div class="container clearfix">
44         <div class="item left">
45             <div class="bg">
46                 <img style="height: 150px; width: 180px;" src="1.jpg">
47             </div>
48             <div class="text">
49                 <div style="z-index:9;position: absolute;left: 0;right: 0;top: 0;bottom: 0;background-color: black;opacity: 0.6"></div>
50                 <div style="z-index:10;position: absolute;left: 0;right: 0;top: 0;bottom: 0;">1000</div>
51             </div>
52         </div>
53     </div>
54 </body>
55 </html>
hover应用一
  1 <!DOCTYPE html>
  2 <html lang="en">
  3 <head>
  4     <meta charset="UTF-8">
  5     <title>Title</title>
  6     <style>
  7         body{
  8             margin: 0;
  9         }
 10         .left{
 11             float: left;
 12         }
 13         .right{
 14             float: right;
 15         }
 16         .pg-header{
 17             height: 48px;
 18             line-height: 48px;
 19             background-color: #303a40;
 20             color: white;
 21         }
 22         .pg-header .logo{
 23             float: left;
 24             width: 200px;
 25             text-align: center;
 26         }
 27         .pg-header .user{
 28             padding: 0 20px;
 29             height: 48px;
 30             position: relative;
 31         }
 32         .pg-header .user:hover{
 33             background-color: #425a66;
 34         }
 35         .pg-header .user .a{
 36             height: 48px;
 37         }
 38         .pg-header .user .a img{
 39             width: 40px;
 40             height: 40px;
 41             margin-top: 4px;
 42             border-radius: 50%;
 43         }
 44         .pg-header .user .more{
 45             width:200px;
 46             border: 1px solid darkgreen;
 47             position: absolute;
 48             top:48px;
 49             right: 20px;
 50             background-color: #C0C0C0;
 51             display: none;
 52             z-index: 9999;
 53         }
 54         .pg-header .user:hover .more{
 55             display: block;
 56         }
 57         .pg-header .user .more a{
 58             display: block;
 59         }
 60         .pg-body .body-menu{
 61             position: absolute;
 62             top: 50px;
 63             bottom: 0;
 64             left: 0;
 65             width: 200px;
 66             border: 1px solid #336699;
 67         }
 68         .pg-body .body-content{
 69             position: absolute;
 70             top: 50px;
 71             bottom: 0;
 72             left: 210px;
 73             right: 0;
 74             border: 1px solid #336699;
 75             overflow: auto;
 76             z-index: 10;
 77         }
 78 
 79     </style>
 80 </head>
 81 <body>
 82     <div class="pg-header">
 83         <div class="logo">Python二班</div>
 84 
 85         <div class="user right" style="position: relative">
 86             <a class="a">
 87                 <img src="1.jpg">
 88             </a>
 89             <div class="more">
 90                 <a>我的信息</a>
 91                 <a>注销</a>
 92             </div>
 93         </div>
 94 
 95     </div>
 96     <div class="pg-body">
 97         <div class="body-menu"></div>
 98         <div class="body-content">
 99             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
100             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
101             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
102             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
103             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
104             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
105             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
106             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
107             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
108             <p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p><p>asdfa</p>
109         </div>
110     </div>
111 </body>
112 </html>
hover应用二

anchor伪类:专用于控制链接的显示效果

a:link(没有接触过的链接),用于定义了链接的常规状态。

a:hover(鼠标放在链接上的状态),用于产生视觉效果。

a:visited(访问过的链接),用于阅读文章,能清楚的判断已经访问过的链接。

a:active(在链接上按下鼠标时的状态),用于表现鼠标按下时的链接状态。

伪类选择器 : 伪类指的是标签的不同状态:

           a ==> 点过状态 没有点过的状态 鼠标悬浮状态 激活状态

a:link {color: #FF0000} /* 未访问的链接 */

a:visited {color: #00FF00} /* 已访问的链接 */

a:hover {color: #FF00FF} /* 鼠标移动到链接上 */

a:active {color: #0000FF} /* 选定的链接 */ 格式: 标签:伪类名称{ css代码; }
 1 <style type="text/css">
 2     a:link{
 3         color: red;
 4     }
 5     a:visited {
 6         color: blue;
 7     }
 8     a:hover {
 9         color: green;
10     }
11     a:active {
12         color: yellow;
13     }
14 </style>
15 </head>
16 <body>
17     <a href="01-hello-world.html">hello-world</a>
18 </body>
19 </html>
View Code

补充:

1
.outer:hover .right{color: red}

before after伪类 :

:before    p:before       在每个<p>元素之前插入内容
:after     p:after        在每个<p>元素之后插入内容
 p:before        在每个 <p> 元素的内容之前插入内容                    p:before{content:"hello";color:red}
 p:after         在每个 <p> 元素的内容之前插入内容                    p:after{ content:"hello";color:red}

5 css优先级和继承

CSS优先级:

所谓CSS优先级,即是指CSS样式在浏览器中被解析的先后顺序。

样式表中的特殊性描述了不同规则的相对权重,它的基本规则是:
1 内联样式表的权值最高 style=""-------------------1000;    2 统计选择符中的ID属性个数。 #id -------------100   3 统计选择符中的CLASS属性个数。 .class -------------10 4 统计选择符中的HTML标签名个数。 p --------------1

按这些规则将数字符串逐位相加,就得到最终的权重,然后在比较取舍时按照从左到右的顺序逐位比较。

 1 <style>
 2         #p{
 3             color: rebeccapurple;
 4         }
 5         .p{
 6             color: #2459a2;
 7         }
 8         p{
 9             color: yellow;
10         }
11     </style>
12 <p id="p" class="p" style="color: deeppink">hello yuan</p>
View Code
CSS的继承性:
 
 1 继承性: color、text-xxx、font-xxx、line-xxx的属性是可以继承下来。盒模型的属性是不可以继承下来的
 2             a标签有特殊情况,设置a标签的字体颜色 一定要选中a,不要使用继承性
 3             
 4             层叠性: 覆盖
 5             
 6                 (1)行内> id > class > 标签 ****
 7                 
 8                     1000 > 100 > 10 > 1
 9                     
10                 (2)数数 数 id  class 标签
11                 (3)先选中标签,权重一样,以后设置为主
12                 (3)继承来的属性 它的权重为0 ,与选中的标签没有可比性
13                 (4)如果都是继承来的属性,保证就近原则
14                 (5)都是继承来的属性,选择的标签一样近,再去数权重
css的继承性和层叠性
 1 属性:
 2                 width:内容的宽度
 3                 height:内容的高度
 4                 padding:内边距 内容到边框的距离
 5                 border:边框
 6                 margin:外边距  另一个边到另一个边的距离
 7             盒模型的计算:
 8                 总结:如果保证盒模型的大小不变,加padding 就一定要减width或者减height
 9                 前提是:在标准文档流
10                         padding:父子之间调整位置
11                         margin: 兄弟之间调整位置
盒模型
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>
 6         
 7     </title>
 8     <style>
 9     /*继承来的属性 它的权重为0,跟选中的标签没有可比性*/
10         #father1 #father2 #father3{
11             color: red;
12         }
13         #father1 .box2 .box3 p{
14             color: green;
15         }
16 
17     </style>
18 </head>
19 <body>
20     <div class="box1" id="father1">
21         <ul class="box2" id="father2">
22             <li class="box3" id="father3">
23                 <p class="box4" id="child">猜猜我的颜色</p>
24             </li>
25         </ul>
26     </div>
27 </body>
28 </html>
29 
30 最终颜色为绿色
示例1
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>
 6         
 7     </title>
 8     <style>
 9     /*继承来的属性 权重为0*/
10 
11     /*如果是继承来的属性,就近原则,谁离目标最近谁厉害*/
12         /*#father1 .box2{
13             color: red;         //最终红色
14         }
15         .box1{
16             color: green;
17         }*/
18         /*都是继承来的 ,都一样深,选择的标签一样近,再去数权重*/
19 
20         #father1 #father2 .box3{
21              color: red;          //最终红色
22         }
23         #father1 .box2 .box3{
24             color: green;
25         }
26 
27     </style>
28 </head>
29 <body>
30     <div class="box1" id="father1">
31         <ul class="box2" id="father2">
32             <li class="box3" id="father3">
33                 <p class="box4" id="child">猜猜我的颜色</p>
34             </li>
35         </ul>
36     </div>
37 </body>
38 </html>
示例2

 

  继承是CSS的一个主要特征,它是依赖于祖先-后代的关系的。继承是一种机制,它允许样式不仅可以应用于某个特定的元素,还可以应用于它的后代。例如一个BODY定义了的颜色值也会应用到段落的文本中。
1
body{color:red;}       <p>helloyuan</p>

这段文字都继承了由body {color:red;}样式定义的颜色。然而CSS继承性的权重是非常低的,是比普通元素的权重还要低的0。

1
p{color:green}

发现只需要给加个颜色值就能覆盖掉它继承的样式颜色。由此可见:任何显示申明的规则都可以覆盖其继承样式。 

      此外,继承是CSS重要的一部分,我们甚至不用去考虑它为什么能够这样,但CSS继承也是有限制的。有一些属性不能被继承,如:border, margin, padding, background等。

1 div{
2   border:1px solid #222
3 }
4 
5 <div>hello <p>yuan</p> </div>
View Code

附加说明:

1 1、文内的样式优先级为1,0,0,0,所以始终高于外部定义。这里文内样式指形如<div style="color:red>blah</div>的样式,而外部定义指经由<link>或<style>卷标定义的规则。
2 
3   2、有!important声明的规则高于一切。
4 
5   3、如果!important声明冲突,则比较优先权。
6 
7   4、如果优先权一样,则按照在源码中出现的顺序决定,后来者居上。
8 
9   5、由继承而得到的样式没有specificity的计算,它低于一切其它规则(比如全局选择符*定义的规则)。
View Code

三  CSS的常用属性 

z-index:10;                  元素叠加顺序,值大的在上层

opacity:0.1;                 透明度

overflow:auto;               加滚动条     

overflow:scroll;             加滚动条

overflow:hidden;             将超出的部分隐藏

cursor:pointer;              小手

*{   margin:0;
     padding:0;}             相当于初始化,一般不要用这个,消耗太大,可以用css reset tools: https://meyerweb.com/eric/tools/css/reset/

/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
    display: block;
}
body {
    line-height: 1;
}
ol, ul {
    list-style: none;
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
css reset tools

a{text-decoration:none;}     将a标签内的文本下的线去掉,默认是underline 下划线, overline 上划线

div{margin:0 auto;}          将div居中

min-height:700px;            高度自适应

color:red!important;         有!important的优先

注:   id一般用下划线,如 id=‘a_b’
      class一般用中划线,如 class='a-b'
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title></title>
 6     <style>
 7         /*第一步:拷贝项目下面生成的font-face*/
 8         
 9         @font-face {font-family: 'iconfont';
10             src: url('./font/iconfont.eot');
11             src: url('./font/iconfont.eot?#iefix') format('embedded-opentype'),
12             url('./font/iconfont.woff') format('woff'),
13             url('./font/iconfont.ttf') format('truetype'),
14             url('./font/iconfont.svg#iconfont') format('svg');
15         }
16 
17         .iconfont{
18             font-family:"iconfont" !important;
19             font-size:16px;font-style:normal;
20             -webkit-font-smoothing: antialiased;
21             -webkit-text-stroke-width: 0.2px;
22             -moz-osx-font-smoothing: grayscale;
23         }
24         .aa{
25             font-size: 20px;
26         }
27         .tt{
28             font-size: 26px;
29         }
30     </style>
31 </head>
32 <body>
33     <i class="iconfont aa">&#xe600;</i>
34     <span class="iconfont tt">&#xe618;</span>
35     
36 </body>
37 </html>
iconfont的使用

1  颜色属性

1
2
3
4
5
6
7
<div style="color:blueviolet">ppppp</div>
 
<div style="color:#ffee33">ppppp</div>
 
<div style="color:rgb(255,0,0)">ppppp</div>
 
<div style="color:rgba(255,0,0,0.5)">ppppp</div>

2  字体属性

1
2
3
4
5
6
7
font-size: 20px/50%/larger
 
font-family:'Lucida Bright'
 
font-weight: lighter/bold/border/
 
<h1 style="font-style: oblique">老男孩</h1>

3  背景属性

background-color: cornflowerblue

background-image: url('1.jpg');

background-repeat: no-repeat;(repeat:平铺满)

background-position: right top(20px 20px);(横向:left center right)(纵向:top center bottom)

      简写:<body style="background: 20px 20px no-repeat #ff4 url('1.jpg')">

              <div style="width: 300px;height: 300px;background: 20px 20px no-repeat #ff4 url('1.jpg')"> 

注意:如果将背景属性加在body上,要记得给body加上一个height,否则结果异常,这是因为body为空,无法撑起背景图片;另外,如果此时要设置一个width=100px,你也看不出效果,除非你设置出html。   

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         html{
 8             background-color: antiquewhite;
 9             
10         }
11         body{
12             width: 100px;
13             height: 600px;
14             background-color: deeppink;
15             background-image: url(1.jpg);
16             background-repeat: no-repeat;
17             background-position: center center;
18         }
19     </style>
20 </head>
21 <body>
22 
23 </body>
24 </html>
View Code

eg:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Document</title>
 6     <style>
 7         .box{
 8             width: 24px;
 9             height: 35px;
10             /*border: 1px solid red;*/
11             /*默认水平平铺和垂直平铺*/
12             /*background-image: url(./xiaohua.jpeg);*/
13             /*background-image: url(https://img.alicdn.com/tfs/TB1eiXTXlTH8KJjy0FiXXcRsXXa-24-595.png);*/
14             /*不平铺*/
15             /*background-repeat: no-repeat;*/
16             /*background-position-x: 0;*/
17             /*background-position-y: -162px;*/
18             /*固定定位*/
19             /*background-attachment: fixed;*/
20             //background: url(https://img.alicdn.com/tfs/TB1eiXTXlTH8KJjy0FiXXcRsXXa-24-595.png) no-repeat 0 -162px;
21         }
22     </style>
23 </head>
24 <body style="">
25     <div class="box">
26         
27     </div>
28 </body>
29 </html>
View Code
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 
 7     <style>
 8 
 9         span{
10             display: inline-block;
11             width: 18px;
12             height: 20px;
13             background-image: url("http://dig.chouti.com/images/icon_18_118.png?v=2.13");
14             background-position: 0 -100px;
15         }
16     </style>
17 </head>
18 <body>
19 
20 
21     <span></span>
22 
23 </body>
24 </html>
View Code

4  文本属性

font-size: 10px;

text-align: center;   横向排列

line-height: 200px;   文本行高 通俗的讲,文字高度加上文字上下的空白区域的高度 50%:基于字体大小的百分比

vertical-align:-4px  设置元素内容的垂直对齐方式 ,只对行内元素有效,对块级元素无效
text-decoration:none;   没有线
text-decoration:underline; 下划线
text-decoration:overline; 上划线
text-decoration:line-through; 删除线 text-align:justify; 两端对齐 text-indent: 150px; 首行缩进 em(根据字体大小变) letter-spacing: 10px; 字母之间的距离 word-spacing: 20px; 单词之间的距离 text-transform: capitalize; 每个单词首字母都大写

思考:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7 
 8 
 9 
10         .outer .item {
11             width: 300px;
12             height: 200px;
13             background-color: chartreuse;
14             display: inline-block;
15         }
16 
17 
18     </style>
19 </head>
20 <body>
21     <div class="outer">
22         <div class="item" style="vertical-align: top">ll
23         </div>
24         <div class="item">
25         </div>
26     </div>
27 
28     <script>
29 
30     </script>
31 </body>
32 </html>
vertical-align

5   边框属性

1
2
3
4
5
6
7
border-style: solid;
 
border-color: chartreuse;
 
border-width: 20px;
 
简写:border: 30px rebeccapurple solid;
 
border-radius:20%;  边框设圆或椭圆
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title></title>
 6     <style>
 7         div{
 8             /*color: transparent;*/
 9             width: 0px;
10             height: 0px;
11             border-bottom: 20px solid red;
12             border-left: 20px solid transparent;
13             border-right: 20px solid transparent;
14         }
15     </style>
16 </head>
17 <body>
18     <div>
19         
20 
21     </div>
22     
23 </body>
24 </html>
制作三角形
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title></title>
 6     <style>
 7         div{
 8             /*color: transparent;*/
 9             width: 200px;
10             height: 200px;
11             background-color: red;
12             /*制作圆角*/
13             /*border-radius: 3px;*/
14             /*border-radius: 100px;*/
15             border-radius: 50%;
16         }
17     </style>
18 </head>
19 <body>
20     <div>
21         
22 
23     </div>
24     
25 </body>
26 </html>

 

6   列表属性

1
2
3
4
ul,ol{   list-style: decimal-leading-zero;
         list-style: none; <br>         list-style: circle;
         list-style: upper-alpha;
         list-style: disc; }
      list-style-type:none;

7  dispaly属性

1
2
3
none
block
inline
inline-block

display:inline-block可做列表布局,其中的类似于图片间的间隙小bug可以通过如下设置解决:

1
2
3
4
#outer{
            border: 3px dashed;
            word-spacing: -5px;
        }

8  外边距和内边   

  • margin:            用于控制元素与元素之间的距离;margin的最基本用途就是控制元素周围空间的间隔,从视觉角度上达到相互隔开的目的。
  • padding:           用于控制内容与边框之间的距离;   
  • Border(边框)     围绕在内边距和内容外的边框。
  • Content(内容)   盒子的内容,显示文本和图像。

元素的宽度和高度:

Remark重要: 当您指定一个CSS元素的宽度和高度属性时,你只是设置内容区域的宽度和高度。要知道,完全大小的元素,你还必须添加填充,边框和边距。.

margin:10px 5px 15px 20px;-----------上 右 下 左
margin:10px 5px 15px;----------------上 右左 下
margin:10px 5px;---------------------上下  右左
margin:10px;    ---------------------上右下左

下面的例子中的元素的总宽度为300px:

width:250px;
padding:10px;
border:5px solid gray;
margin:10px;   

 练习: 300px*300px的盒子装着100px*100px的盒子,分别通过margin和padding设置将小盒子 移到大盒子的中间

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7 
 8         .div1{
 9             background-color: aqua;
10             width: 300px;
11             height: 300px;
12         }
13         .div2{
14             background-color: blueviolet;
15             width: 100px;
16             height: 100px;
17         }
18     </style>
19 </head>
20 <body>
21        <div class="div1">
22            <div class="div2"></div>
23            <div class="div2"></div>
24        </div>
25 </body>
26 </html>
View Code

思考1:

       边框在默认情况下会定位于浏览器窗口的左上角,但是并没有紧贴着浏览器的窗口的边框,这是因为body本身也是一个盒子(外层还有html),在默认情况下,   body距离html会有若干像素的margin,具体数值因各个浏览器不尽相同,所以body中的盒子不会紧贴浏览器窗口的边框了,为了验证这一点,加上:

1
2
3
4
body{
    border: 1px solid;
    background-color: cadetblue;
}

>>>>解决方法:

1
2
3
body{
    margin: 0;
}

思考2:

           margin collapse(边界塌陷或者说边界重叠)

          外边距的重叠只产生在普通流文档的上下外边距之间,这个看起来有点奇怪的规则,其实有其现实意义。设想,当我们上下排列一系列规则的块级元素(如段     落P)时,那么块元素之间因为外边距重叠的存在,段落之间就不会产生双倍的距离。又比如停车场

           1兄弟div:上面div的margin-bottom和下面div的margin-top会塌陷,也就是会取上下两者margin里最大值作为显示值

           2父子div    

                   if  父级div中没有 border,padding,inline content,子级div的margin会一直向上找,直到找到某个标签包括border,padding,inline content              中的其中一个,然后按此div 进行margin ;

 1 <!DOCTYPE html>
 2 <html lang="en" style="padding: 0px">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7 
 8         body{
 9             margin: 0px;
10         }
11 
12         .div1{
13             background-color: aqua;
14             width: 300px;
15             height: 300px;
16         }
17         .div2{
18             background-color: blueviolet;
19             width: 100px;
20             height: 100px;
21             margin: 20px;
22 
23         }
24     </style>
25 </head>
26 <body>
27 
28 <div style="background-color: cadetblue;width: 300px;height: 300px"></div>
29 
30        <div class="div1">
31            <div class="div2"></div>
32            <div class="div2"></div>
33        </div>
34 
35 </body>
36 </html>
View Code

 解决方法:

1: border:1px solid transparent
2:  padding:1px
3: over-flow:hidden; 

9 float属性

先来了解一下block元素和inline元素在文档流中的排列方式。

  block元素通常被现实为独立的一块,独占一行,多个block元素会各自新起一行,默认block元素宽度自动填满其父元素宽度。block元素可以设置width、height、margin、padding属性;

  inline元素不会独占一行,多个相邻的行内元素会排列在同一行里,直到一行排列不下,才会新换一行,其宽度随元素的内容而变化。inline元素设置width、height属性无效。inline元素的margin和padding属性。水平方向的padding-left, padding-right, margin-left, margin-right都产生边距效果;但竖直方向的padding-top, padding-bottom, margin-top, margin-bottom不会产生边距效果。

  • 常见的块级元素有 div、form、table、p、pre、h1~h5、dl、ol、ul 等。
  • 常见的内联元素有span、a、strong、em、label、input、select、textarea、img、br等

     

所谓的文档流,指的是元素排版布局过程中,元素会自动从左往右,从上往下的流式排列。

脱离文档流,也就是将元素从普通的布局排版中拿走,其他盒子在定位的时候,会当做脱离文档流的元素不存在而进行定位

只有绝对定位absolute和浮动float才会脱离文档流。

     ---部分无视和完全无视的区别?需要注意的是,使用float脱离文档流时,其他盒子会无视这个元素,但其他盒子内的文本依然会为这个元素让出位置,环绕在周围(可以说是部分无视)。而对于使用absolute position脱离文档流的元素,其他盒子与其他盒子内的文本都会无视它。(可以说是完全无视)

浮动的表现

      定义:浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。由于浮动框不在文档的普通流中,所以文档的普通流中的浮动框之后的块框表现得就像浮动框不存在一样。(注意这里是块框而不是内联元素;浮动框只对它后面的元素造成影响)

注意 当初float被设计的时候就是用来完成文本环绕的效果,所以文本不会被挡住,这是float的特性,即float是一种不彻底的脱离文档流方式。无论多么复杂的布局,其基本出发点均是:“如何在一行显示多个div元素”。

现象1:

      假如某个div元素A是浮动的,如果A元素上一个元素也是浮动的,那么A元素会跟随在上一个元素的后边(如果一行放不下这两个元素,那么A元素会被挤到下一行);如果A元素上一个元素是标准流中的元素,那么A的相对垂直位置不会改变,也就是说A的顶部总是和上一个元素的底部对齐。此外,浮动的框之后的block元素元素会认为这个框不存在,但其中的文本依然会为这个元素让出位置。 浮动的框之后的inline元素,会为这个框空出位置,然后按顺序排列。

现象2:

(1)左右结构div盒子重叠现象,一般是由于相邻两个DIV一个使用浮动一个没有使用浮动。如上面的例1:相邻的两个盒子box2向左浮动、box3未浮动。一个使用浮动一个没有导致DIV不是在同个“平面”上,但内容不会照成覆盖现象,只有DIV形成覆盖现象。

解决方法:要么都不使用浮动;要么都使用float浮动;要么对没有使用float浮动的DIV设置margin样式。

(2)上下结构div盒子重叠现象

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6 <style type="text/css">
 7          * {
 8              margin:0;padding:0;
 9          }
10         .container{
11             border:1px solid red;width:300px;
12         }
13         #box1{
14             background-color:green;float:left;width:100px;height:100px;
15         }
16         #box2{
17             background-color:deeppink; float:right;width:100px;height:100px; 
18         }
19          #box3{
20              background-color:pink;height:40px;
21          }
22 </style>
23 </head>
24 <body>
25 
26         <div class="container">
27                 <div id="box1">box1 向左浮动</div>
28                 <div id="box2">box2 向右浮动</div>
29         </div>
30         <div id="box3">box3</div>
31 </body>
32 </body>
33 </html>
View Code

例子如上:.container和box3的布局是上下结构,上图发现box3跑到了上面,与.container产生了重叠,但文本内容没有发生覆盖,只有div发生覆盖现象。这个原因是因为第一个大盒子里的子元素使用了浮动,脱离了文档流,导致.container没有被撑开。box3认为.container没有高度(未被撑开),因此跑上去了。

解决方法:

1、要么给.container设置固定高度,一般情况下文字内容不确定多少就不能设置固定高度,所以一般不能设置“.container”高度(当然能确定内容多高,这种情况下“.container是可以设置一个高度即可解决覆盖问题。

2、要么清除浮动。

清除浮动:

注:清除浮动主要用:after

  a:已知外层高度时,内部元素浮动时;

  b:未知外层高度时,在沉底位置加上如下方法;

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         .clearfix:after{
 8             content:'.';
 9             display:block;
10             height:0;
11             clear:both;
12             visibility:hidden;  //内容隐藏,位置还在
13         }
14     </style>
15 </head>
16 <body>
17 <div class="div1 clearfix">
18     <div class="div2" style="height:200px;float:left;width:100%;background-color:red"></div>
19     <div class="div3" style="height:200px;float:left;width:100%;background-color:blue"></div>
20     <div class="div4" style="height:200px;float:left;width:100%;background-color:green"></div>
21     <div class="div5" style="height:200px;float:left;width:100%;background-color:gray"></div>
22 </div>
23 </body>
24 </html>
清除浮动主流方法

在非IE浏览器(如Firefox)下,当容器的高度为auto,且容器的内容中有浮动(float为left或right)的元素,在这种情况下,容器的高度不能自动伸长以适应内容的高度,使得内容溢出到容器外面而影响(甚至破坏)布局的现象。这个现象叫浮动溢出,为了防止这个现象的出现而进行的CSS处理,就叫CSS清除浮动。

clear语法:
clear : none | left | right | both

取值:
none : 默认值。允许两边都可以有浮动对象
left : 不允许左边有浮动对象
right : 不允许右边有浮动对象
both : 不允许有浮动对象

但是需要注意的是:clear属性只会对自身起作用,而不会影响其他元素。如果一个元素的右侧有一浮动对象,而这个元素设置了不允许右边有浮动对象,即clear:right,则这个元素会自动下移一格,达到本元素右边没有浮动对象的目的。

方式1(推荐):

.clearfix:after {                 <----在类名为“clearfix”的元素内最后面加入内容; 
    content: ".";                 <----内容为“.”就是一个英文的句号而已。也可以不写。 
    display: block;               <----加入的这个元素转换为块级元素。 
    clear: both;                  <----清除左右两边浮动。 
    visibility: hidden;           <----可见度设为隐藏。注意它和display:none;是有区别的。visibility:hidden;仍然占据空间,只是看不到而已; 
    line-height: 0;               <----行高为0; 
    height: 0;                    <----高度为0; 
    font-size:0;                  <----字体大小为0; 
} 
.clearfix { *zoom:1;}             <----这是针对于IE6的,因为IE6不支持:after伪类,这个神奇的zoom:1让IE6的元素可以清除浮动来包裹内部元素。

整段代码就相当于在浮动元素后面跟了个宽高为0的空div,然后设定它clear:both来达到清除浮动的效果。 
之所以用它,是因为,你不必在html文件中写入大量无意义的空标签,又能清除浮动。 

话说回来,你这段代码真是个累赘啊,这样写不利于维护。 
只要写一个.clearfix就行了,然后在需要清浮动的元素中 添加clearfix类名就好了。 
如:

1
<div class="head clearfix"></div>

方式2:

1
overflow:hidden;

overflow:hidden的含义是超出的部分要裁切隐藏,float的元素虽然不在普通流中,但是他是浮动在普通流之上的,可以把普通流元素+浮动元素想象成一个立方体。如果没有明确设定包含容器高度的情况下,它要计算内容的全部高度才能确定在什么位置hidden,这样浮动元素的高度就要被计算进去。这样包含容器就会被撑开,清除浮动。

注:清除浮动主要方法:     :after

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         .left{
 8             float: left;
 9         }
10         .container{
11             background-color: red;
12         }
13 
14         .container .item{
15             width: 180px;
16             height: 150px;
17             background-color: #303a40;
18             border: 1px solid red;
19         }
20 
21         .clearfix:after{
22             content: '.';
23             display: block;
24             clear: both;
25             visibility: hidden;
26             height: 0;
27         }
28     </style>
29 </head>
30 <body>
31     <div class="container clearfix">
32         <div class="item left"></div>
33         <div class="item left"></div>
34         <div class="item left"></div>
35         <div class="item left"></div>
36         <div class="item left"></div>
37         <div class="item left"></div>
38         <div class="item left"></div>
39         <div class="item left"></div>
40     </div>
41     <div>asdf</div>
42 </body>
43 </html>
清除浮动实例

10 position(定位)

1 static

static 默认值,无定位,不能当作绝对定位的参照物,并且设置标签对象的left、top等值是不起作用的的。

2  position: relative/absolute

    relative 相对定位。相对定位是相对于该元素在文档流中的原始位置,即以自己原始位置为参照物。有趣的是,即使设定了元素的相对定位以及偏移值,元素还占有着原来的位置,即占据文档流空间。对象遵循正常文档流,但将依据top,right,bottom,left等属性在正常文档流中偏移位置。而其层叠通过z-index属性定义。

注意:position:relative的一个主要用法:方便绝对定位元素找到参照物。

    absolute 绝对定位。

      定义:设置为绝对定位的元素框从文档流完全删除,并相对于最近的已定位祖先元素定位,如果元素没有已定位的祖先元素,那么它的位置相对于最初的包含块(即body元素)。元素原先在正常文档流中所占的空间会关闭,就好像该元素原来不存在一样。元素定位后生成一个块级框,而不论原来它在正常流中生成何种类型的框。

重点:如果父级设置了position属性,例如position:relative;,那么子元素就会以父级的左上角为原始点进行定位。这样能很好的解决自适应网站的标签偏离问题,即父级为自适应的,那我子元素就设置position:absolute;父元素设置position:relative;,然后Top、Right、Bottom、Left用百分比宽度表示。

      另外,对象脱离正常文档流,使用top,right,bottom,left等属性进行绝对定位。而其层叠通过z-index属性定义。

总结:参照物用相对定位,子元素用绝对定位,并且保证相对定位参照物不会偏移即可。

让一个绝对定位的盒子居中
            left:50%;
            margin-left:- 宽度的一半
- absolute
                
        1.脱标:不占位置 
        2.层级提高
参照物:
        单个盒子
            如果以top描述,是以页面的左上角为参考点(跟浏览器的左上角区分)
                
            如果以bottom描述,是以浏览器的左上角为参考点
                
        父子盒子之间
                
            如果父辈盒子设置相对定位。子盒子设置绝对定位,以父辈盒子的0,0为参考点
z-index的使用
    1、z-index 值表示谁压着谁,数值大的压盖住数值小的,
    2、只有定位了的元素,才能有z-index,也就是说,不管相对定位,绝对定位,固定定位,都可以使用z-index,而浮动元素不能使用z-index
    3、z-index值没有单位,就是一个正整数,默认的z-index值为0,如果大家都没有z-index值,或者z-index值一样,那么谁写在HTML后面,谁在上面压着别人,定位了元素,永远压住没有定位的元素。
    4、从父现象:父亲怂了,儿子再牛逼也没用

3  position:fixed

        fixed:对象脱离正常文档流,使用top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。而其层叠通过z-index属性 定义。 注意点: 一个元素若设置了 position:absolute | fixed; 则该元素就不能设置float。这 是一个常识性的知识点,因为这是两个不同的流,一个是浮动流,另一个是“定位流”。但是 relative 却可以。因为它原本所占的空间仍然占据文档流。

       在理论上,被设置为fixed的元素会被定位于浏览器窗口的一个指定坐标,不论窗口是否滚动,它都会固定在这个位置。

仅使用margin属性布局绝对定位元素

此情况,margin-bottom 和margin-right的值不再对文档流中的元素产生影响,因为该元素已经脱离了文档流。另外,不管它的祖先元素有没有定位,都是以文档流中原来所在的位置上偏移参照物。  
  图9中,使用margin属性布局相对定位元素。
  层级关系为:
  <div ——————————— position:relative;
  <div—————————-没有设置为定位元素,不是参照物
  <div———————-没有设置为定位元素,不是参照物
  <div box1
  <div box2 ——–position:absolute; margin-top:50px; margin-left:120px;
  <div box3
  效果图:

 

  

11 关于css的拾遗

11.1 inline-block 的间隙

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7         a{
 8             display: inline-block;
 9             background-color: #2459a2;
10             width: 100px;
11             height: 100px;
12         }
13     </style>
14 </head>
15 <body>
16 
17 <a>111</a>
18 <a>222</a>
19 <a>333</a>
20 
21 </body>
22 </html>
View Code

inline-block默认的空格符就是标签与标签之间的空隙造成的。

(1) 我们可以通过margin:-3px来解决,但是

1.我们布局肯定很多元素,不可能每个都添加margin负这样维护成本太大了

2.我们线上代码如果压缩,那么我们就不存在哪个4px的问题了,那么我们的margin负就回造成布局混乱!

(2)我们可以给几个标签加一个父级div,然后:

1
div{word-spacing: -5px;}  

11.2 word-wrap & word-break:

word-wrap:

the word-wrap CSS property is used to specify whether or not the browser is allowd to 
break lines within words in order to prevent overflow when an otherwise unbreakable 
string is too long to fit.

The word-wrap property was invented by Microsoft and added to CSS3. It allows long words to be able to be broken and wrap onto the next line. It takes in two values; normal or break-word.

word-break:

The word-break CSS property is used to specify how (or if) to break lines within words

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Title</title>
 6     <style>
 7 
 8 
 9         .p1{
10             width: 100px;
11             background-color: #84a42b;
12             word-wrap: break-word;
13             word-break: break-all;
14         }
15         .p2{
16             width: 100px;
17             background-color: darkgoldenrod;
18             word-wrap: break-word;
19             word-break: break-all;
20         }
21     </style>
22 </head>
23 <body>
24 
25 
26 <p class="p1">hello yuan hello yuan hello yuan hello yuan hello yuan</p>
27 
28 <p class="p2">helloyuanhelloyuanhelloyuanhelloyuanhelloyuanhelloyuan</p>
29 
30 
31 </body>
32 </html>
View Code

1.3

      一旦给元素加上absolute或float就相当于给元素加上了display:block;。什么意思呢?比如内联元素span默认宽度是自适应的,你给其加上width是不起作用的。要想width定宽,你需要将span设成display:block。但如果你给span加上absolute或float,那span的display属性自动就变成block,就可以指定width了。

1.4 快写

1
2
3
div   tab
a     tab
div.main>ul>li.c*4    tab

1.5 display:flex

1.6 响应式布局

 

参考文献:

http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html

http://www.jianshu.com/p/a3da5e27d22b

posted on 2019-04-15 16:17  始终不够啊  阅读(131)  评论(0编辑  收藏  举报