CSS-01

01-css的引入方式

在HTML中引入css方式总共由三种方式:

  1,行内样式

  2,内接样式

  3,外接样式

    3.1 连接式

    3.2导入式

行内样式

<div>
        <p style="color: green">
            我是一个段落
        </p>
</div>

内接样式

<head>
    <meta charset="UTF-8">
    <title>导入方式</title>
    <style type="text/css">
        span{
            color: yellow;
        }
    </style>
</head>

外接样式-链接式

<link rel="styleheet" href="./index.css">

外接样式-导入式

<style type="text/css">
    @import url("./index.css")
</style>

02-css的选择器

css的选择器: 1,基本选择器. 2,高级选择器

基本选择器包含:

1.标签选择器
标签选择器可以选中所有的标签元素,比如div,ul,li ,p等等,不管标签藏的多深,都能选中,选中的是所有的,而不是某一个,所以说 "共性" 而不是 ”特性“

body{
            color: gray;
            font-size: 12px;
        }
        p{
            color: red;
            font-size: 20px;
        }
        span{
            color: yellow
        }

2,id选择器

# 选中id

同一个页面中id不能重复

任何的标签都可以设置id

id命名规范 要以字母可以 有数字 下划线 - 大小写严格区分 aa和AA都是两个不一样的属性值

#box{
            background: green;
        }
        #s1{
            color: red
        }
        #s2{
            font-size: 30;
        }

3.类选择器

3.1所谓类,就是class, .class与id非常相似 任何的标签都可以加类但是类式可以重复,属于归类的概念

3.2用一个标签中可以携带多个类,用空格隔开

 

 1 .lv{
 2     color: green;
 3 
 4 }
 5 .big{
 6     font-size: 40px;
 7 }
 8 .line{
 9     text-decoration: underline;
10 }
1 <!-- 公共类    共有的属性 -->
2     <div>
3         <p class="lv big">段落1</p>
4         <p class="lv line">段落2</p>
5         <p class="line big">段落3</p>
6     </div>

总结:

  不要去试图用一个类将我们的页面写完.这个标签要携带多个类,共同设置样式

  每个类要尽可能的小,有公共该奶奶,能够让更多的标签使用

 

03-高级选择器

高级选择器分为: 后代选择器, 子代选择器, 并集选择器, 交集选择器

后代选择器

使用空格表示后代选择器,顾名思义: 父元素的后代(包括儿子,孙子, 重孙子)

.container p{
    color: red;
}    
.container .item p{
    color:yellow;
}    

子代选择器

使用>表示子代选择器.比如div>p,仅仅表示的式当前div元素选中的子代(不包含子孙)元素p

1 .container>p{
2     color: yellowgreen;
3 }

并集选择器

多个选择器之间使用逗号隔开,表示选中的页面中的多个标签.一些共性的元素,可以使用并集选择器

1 /*并集选择器*/
2 h3,a{
3     color: #008000;
4     text-decoration: none;
5                 
6 }

交集选择器

使用.表示交集选择器,第一个标签必须式标签选择器第二个必须是类选择器语法:div.active

比如有一个<h4 class="active"></h4>这样的标签

那么

 1 h4{
 2     width: 100px;
 3     font-size: 14px;
 4 }
 5 .active{
 6     color: red;
 7     text-decoration: underline;
 8 }
 9 /* 交集选择器 */
10 h4.active{
11     background: #00BFFF;
12 }

他表示两者选中之后元素共有的特性

 

04-属性选择器

属性选择器,字面意思就是根据标签中的属性,选中当前的标签

语法:

 1 /*根据属性查找*/
 2             /*[for]{
 3                 color: red;
 4             }*/
 5             
 6             /*找到for属性的等于username的元素 字体颜色设为红色*/
 7             /*[for='username']{
 8                 color: yellow;
 9             }*/
10             
11             /*以....开头  ^*/ 
12             /*[for^='user']{
13                 color: #008000;
14             }*/
15             
16             /*以....结尾   $*/
17             /*[for$='vvip']{
18                 color: red;
19             }*/
20             
21             /*包含某元素的标签*/
22             /*[for*="vip"]{
23                 color: #00BFFF;
24             }*/
25             
26             /**/
27             
28             /*指定单词的属性*/
29             label[for~='user1']{
30                 color: red;
31             }
32             
33             input[type='text']{
34                 background: red;
35             }

 

05-伪类选择器

伪类选择器一般会用在超链接a标签中,使用a标签的伪类选择器,我们一定要遵循LoVe HAte

 1               /*没有被访问的a标签的样式*/
 2         .box ul li.item1 a:link{
 3             
 4             color: #666;
 5         }
 6         /*访问过后的a标签的样式*/
 7         .box ul li.item2 a:visited{
 8             
 9             color: yellow;
10         }
11         /*鼠标悬停时a标签的样式*/
12         .box ul li.item3 a:hover{
13             
14             color: green;
15         }
16         /*鼠标摁住的时候a标签的样式*/
17         .box ul li.item4 a:active{
18             
19             color: yellowgreen;
20         }

css3 的选择器nth-child()

              /*选中第一个元素*/
        div ul li:first-child{
            font-size: 20px;
            color: red;
        }
        /*选中最后一个元素*/
        div ul li:last-child{
            font-size: 20px;
            color: yellow;
        }
        
        /*选中当前指定的元素  数值从1开始*/
        div ul li:nth-child(3){
            font-size: 30px;
            color: purple;
        }
        
        /*n表示选中所有,这里面必须是n, 从0开始的  0的时候表示没有选中*/
        div ul li:nth-child(n){
            font-size: 40px;
            color: red;
        }
        
        /*偶数*/
        div ul li:nth-child(2n){
            font-size: 50px;
            color: gold;
        }
        /*奇数*/
        div ul li:nth-child(2n-1){
            font-size: 50px;
            color: yellow;
        }
        /*隔几换色  隔行换色
             隔4换色 就是5n+1,隔3换色就是4n+1
            */
        
        div ul li:nth-child(5n+1){
            font-size: 50px;
            color: red;
        }
View Code

 

06-伪元素选择器

/*设置第一个首字母的样式*/
        p:first-letter{
            color: red;
            font-size: 30px;

        }
        
/* 在....之前 添加内容   这个属性使用不是很频繁 了解  使用此伪元素选择器一定要结合content属性*/
        p:before{
            content:'alex';
        }
        
        
/*在....之后 添加内容,使用非常频繁 通常与咱们后面要讲到布局 有很大的关联(清除浮动)*/
        p:after{
            content:'&';
            color: red;
            font-size: 40px;
        }

 

07-css的继承性和层叠性

css有两大特性: 继承性和层叠性

继承性:

  面向对象语言都会存在继承的概念,在面向对象语言中,继承的特点: 继承了父类的属性和方法.那么我们现在主要要研究css, css就是在设置属性的.不会牵扯到方法的层面

  继承: 给父级设置一些属性,子级继承了父级的该属性,这就是说我们的css中的继承

  记住: 有一些属性可以继承下来: color, font-*, text-*, line-*.主要时文本级的标签元素

  但是像一些盒子元素属性,定位的元素(浮动,绝对定位,固定定位)不能继承

层叠性:

  层叠性: 权重的标签覆盖掉了权重小的标签,说白了,就是被干掉了

  权重: 对的权重大,浏览器就会显示谁的属性

  谁的权重大?非常简单的小学数数

数: id的数量 class的数量 标签的属性,顺序不能乱

/*1  0  0 */显示红色
#box{


    color: red; 
}
/*0  1  0*/
.container{
    color: yellow;
}
/*0  0  1*/
p{
    color: purple;
}

是不是感觉明白了?好的在深入理解下

1     <div id='box1' class="wrap1">
2         <div id="box2" class="wrap2">
3             <div id="box3" class="wrap3">
4                 <p>再来猜猜我是什么颜色?</p>
5             </div>
6         </div>
7     </div>
View Code
        #box1 #box2 p{
            color: yellow;
        }
        
        #box2 .wrap3 p{
            color: red;
        }
        
        div div #box3 p{
            color: purple;
        }
        
        
        div.wrap1 div.wrap2 div.wrap3 p{
            color: blue;
        }
View Code

整这么多华丽花哨的实际就是按照id, 类, 标签的数量排除一个数字,谁的数字最大,就以谁的设置

小总结一下:

总结:
1.先看标签元素有没有被选中,如果选中了,就数数 (id,class,标签的数量) 谁的权重大 就显示谁的属性。权重一样大,后来者居上
2.如果没有被选中标签元素,权重为0。
如果属性都是被继承下来的 权重都是0 。权重都是0:"就近原则" : 谁描述的近,就显示谁的属性

 

08-层叠性权重相同处理

第一种现象:当权重相同时,以后来设置的属性为准,前提一定要权重相同

#box2 .wrap3 p{
    color: yellow;
}
        
#box1 .wrap2 p{
    color: red;
}

我们会发现此时显示的是红色的。

 

第二种现象: 第一个选择器没有选中内层标签,那么它是通过继承来设置的属性,那么它的权重为0。第二个选择器选中了内层标签,有权重。

所以 继承来的元素 权重为0。跟选中的元素没有可比性。

#box1 #box2 .wrap3{
    color: red;
}
#box2 .wrap3 p{
    color: green;
}

我们会发现此时显示的是绿色的。

 

第三种现象:如果都是继承来的属性,谁描述的近,显示谁的属性。'就近原则'

#box1 #box2 .wrap3{
    color: red;
}
 .wrap1 #box2{
    color: green;
}

!important 的使用。

!important:设置权重为无限大 
!important 不影响继承来的权重,只影响选中的元素。不要随便使用!important,因为使用它会影响页面的布局

 

09-和模型

盒模型

在css中,"box model"这一术语就是来设计和布局时使用,然后子啊网页中基本上都会显示一些方方正正的盒子.我们称为这种盒子叫盒模型

盒模型有两种: 标准模型和IE模型.我们这里重点讲标准模型

 

盒模型的属性

width: 内容的宽度

height: 内容的高度

padding: 内边距,边框到内容的距离

border: 边框,就是指的盒子的宽度

margin: 外边距,盒子边框到附近盒子的距离

 

盒模型的计算

如果一个盒子设置了pading, border, width, margin

盒子的真是宽度=width+2*padding+2*broder

盒子的真是宽度=height+2*padding+2*border

 

那么在这这里要注意看了,标准盒模型,width不能盒子真是的宽度.

另外如果要保持盒子真实宽度,那么加padding就一定要减width, 减padding就一定要加width.真是高度一样设置

 

10-padding(内边距)

padding

padding:就是内边距的意思,它是边框到内容之间的距离

另外padding的区域是由背景yanse的,并且背景颜色和内容的颜色,也就是说background-color这个属性讲填充所有的border以内的区域

 

padding的设置

描述的方法有两种

1, 写小属性,分别设置不同方向的padding

padding-top: 30px;
padding-right: 30px;
padding-bottom: 30px;
padding-left: 30px;

2,写综合苏醒,用空格隔开

/*上 右 下 左*/
padding: 20px 30px 40px 50px ;

/*上 左右  下*/
padding: 20px 30px 40px;

/* 上下 左右*/
padding: 20px 30px;
            
/*上下左右*/
padding: 20px;

一些标签默认由padding

比如ul标签,有默认的padding-left值

那么我们一般在做网站的时候,要清楚页面标签中默认的padding和margin,以便于我们更好去调整元素的位置

我们现在初学可以使用通配符选择器

*{
  padding:0;
  margin:0;    
}

But,这种效率不高

所以我们要使用并集选择器来选中页面中应有的标签(不同背,因为有人已经给咱们写好了这些清理默认的样式表, resert.css)

https://meyerweb.com/eric/tools/css/reset/

 

11-border

边框

border: 边框的意思,描述盒子的边框

边框有三个要素: 粗细 线性样式 颜色

border: solid

如果颜色不写,默认是黑色.如果粗细不写,不显示边框,如果只写线性样式,默认的有上下左右3px的宽度,实体样式,并且黑色的边框

按照3要素来写border

border-width: 3px;
border-style: solid;
border-color: red;
/*
border-width: 5px 10px;
border-style: solid dotted double dashed;
border-color: red green yellow;
*/

按照方向划分

border-top-width: 10px;
border-top-color: red;
border-top-style: solid;

border-right-width: 10px;
border-right-color: red;
border-right-style: solid;

border-bottom-width: 10px;
border-bottom-color: red;
border-bottom-style: solid;

border-left-width: 10px;
border-left-color: red;
border-left-style:solid;

上面12条语句,相当于bordr: 10px solid red

另外还可以这样:

border-top: 10px solid red;
border-right: 10px solid red;
border-bottom: 10px solid red;
border-left: 10pxb solid red;

border:none;

border:0;

表示border没有设置样式。

使用border来制作小三角

/*小三角 箭头指向下方*/
        div{
            width: 0;
            height: 0;
            border-bottom: 20px solid red;
            border-left: 20px solid transparent;
            border-right: 20px solid transparent;
        }

 

12-简单认识下margin

margin:  外边距的意思.白哦是边框到最近盒子的距离.

/*表示四个方向的外边距离为20px*/
margin: 20px;
/*表示盒子向下移动了30px*/
margin-top: 30px;
/*表示盒子向右移动了50px*/
margin-left: 50px;

margin-bottom: 100px;

 

13-标准文档流

什么是标准文档流

宏观的讲,我们讲的web页面和ps等设计软件有本质的区别,web网页的制作,是个"流", 从上而下,像"织毛衣". 而设计软件,相往哪里画东西,就去哪里画

空白折叠现象

多个空格会被合并成一个空格显示高浏览器页面中,img标签换行写.会发现每张图之间有间隙.如果在一行内写img标签.就解决了这个问题,但是我们不会去写我们的thml结构.这种现象称为空白折叠现象.

 

2,高矮不齐,底边对齐

文字还有图片大小不一,都会让我们页面的元素出现高矮不齐的现象,但是在浏览器查看我们的页面总会发现底边对齐

 

3,自动换行,一行写不满,换行写

如果在一行内写文字,文字过多,那么浏览器会自动换行去显示我们的文字

 

14-块级元素和行内元素

学习的初期,我们就知道,标准文档流等级森严.标签分为两种等级:

  行内元素

  块级元素

比如h1标签和span,同时设置宽高,来浏览器效果,那么你会发现:

 

行内元素和块级元素的区别: (非常重要)

行内元素:

  与其他行内元素并排:

  不能设置宽,高,默认的宽度,就是文字的宽度

块级元素

  霸占一行,不能与其他任何元素并列

  能接受宽,高.如果不能设置宽高,那么宽高讲默认变为父亲的100%

块级元素和行内元素的分类

在以前的HTML知识中,我们已经将标签分过类,当时为了: 文本级,容器级.

从HTML的角度来讲,标签分为:

  文本级标签: p, span, a, b, i, u, em

  容器级标签: div, h系列, li, dt, dd

  ps: 为什么说p是文本级标签呢?因为p里面只能放文字&图片&表单元素,p里面不饿能放h和ul, p里面也不能放p

 

现在, 从css的角度讲, css的分类和上面很像,就p不一样:

  行内元素: 除了p之外,所有的文本级标签,都是行内元素,p是文本级,但是是个块级元素

  块级元素: 所有的容器级标签都是跨级元素,还有p标签.

块级元素和行内元素的相互转换

我们可以通过display属性讲块级元素和行内元素进行相互转换,display即"显示模式"

块级元素可以转换为行内元素:

一旦,给一个块级元素(比如div)设置:

display: inline

那么,这个标签将立即变为行内元素,此时他和一个span无异,inline就是"行内".也就是说:

  此时这个div不饿能设置宽度,高度了

  此时这个div可以和别人并排了

行内元素转换为块级元素

同样的道理,一旦给你行内元素(比如span)设置:

display: block

那么,这个标签将立即变为块级元素,此时他它和一个div无异,block是"块"的意思.也就是说:

  此时这个span能够设置宽度,高度

  此时则会个span必须霸占一行, 别人无法和他并排

  如果不设置宽度,将撑满父亲

 

标准流里面的限制非常多,导致很多页面效果无法实现,如果我们想在就要并排,并且就要设置宽高,那该怎么办呢?办法是:移民!脱离标准流

css中一共有三种手段,是一个元素脱离标准文档流

  1,浮动

  2,绝对定位

  3,固定定位

 

posted @ 2018-08-08 16:23  猴里吧唧  阅读(133)  评论(0)    收藏  举报