02-CSS常用样式

  

  本篇主要介绍css的常用样式,以及网页布局相关知识、绝对定位和相对定位,盒子模型、css权重、以及css选择器;

绪论:CSS基本介绍

  为了让网页元素的样式更加丰富,也为了让网页的内容和样式能拆分开,CSS由此思想而诞生,CSS是 Cascading Style Sheets 的首字母缩写,意思是层叠样式表。有了CSS,html中大部分表现样式的标签就废弃不用了,html只负责文档的结构和内容,表现形式完全交给CSS,html文档变得更加简洁。

  例如你看到有样式的搜索框可能是这样的:

  

  而没有样式的可能是这样的:

    

  故我们需要知道的是(网页三剑客--HTML、css、JavaScript):

    html主要负责网页的结构和内容,css用来负责表现,让网页更加漂亮,而后面要讲的JavaScript主要用来做动画和交互效果。

 

一、CSS载入方式

 css引入页面的方式有三种:

  1、内联式:通过标签的style属性,在标签上直接写样式。

<div style="width:100px; height:100px; background:red ">内联式</div>

  2、嵌入式:通过style标签,在网页上创建嵌入的样式表。

<style type="text/css">
    div{ width:100px; height:100px; background:red }
    ......
</style>

  3、外链式:通过link标签,链接外部样式文件到页面中。(推荐)

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

  

二、CSS选择器

  首先,什么是选择器呢?我们要给HTML标签添加样式,那么在嵌入式和外链式中我们怎么找到该标签呢?便是通过选择器,大致有以下几种:

  1、标签选择器

  标签选择器,此种选择器影响范围大,一般用来做一些通用设置,或用在层级选择器中。

div{color:red} 
......
<div>这是第一个div</div>   <!-- 对应以上样式 -->
<div>这是第二个div</div>   <!-- 对应以上样式 -->

 

  2、类选择器

   通过类名来选择元素,一个类可应用于多个元素,一个元素上也可以使用多个类,应用灵活,可复用,是css中应用最多的一种选择器。

.blue{color:blue}
.big{font-size:20px}
.box{width:100px;height:100px;background:gold} 
......
<div class="blue">....</div>
<h3 class="blue big box">....</h3>
<p class="blue box">....</p>

 

  3、层级选择器

  主要应用在标签嵌套的结构中,层级选择器,是结合上面的两种选择器来写的选择器,它可与标签选择器结合使用,减少命名,同时也可以通过层级,限制样式的作用范围。

.con{width:300px;height:80px;background:green}
.con span{color:red}
.con .pink{color:pink}
.con .gold{color:gold}
......
<div class="con">
    <span>....</span>
    <a href="#" class="pink">....</a>
    <a href="#" class="gold">...</a>
</div>
<span>....</span>
<a href="#" class="pink">....</a>

 

  4、id选择器

  通过id名来选择元素,元素的id名称不能重复,所以一个样式设置项只能对应于页面上一个元素,不能复用,id名一般给程序使用,所以不推荐使用id作为选择器。

#box{color:red} 
......
<p id="box">这是一个段落标签</p>   <!-- 对应以上一条样式,其它元素不允许应用此样式 -->
<p>这是第二个段落标签</p> <!-- 无法应用以上样式,每个标签只能有唯一的id名 -->

 

  5、组选择器

  多个选择器,如果有同样的样式设置,可以使用组选择器。 举例:

.box1,.box2,.box3{width:100px;height:100px}
.box1{background:red}
.box2{background:pink}
.box2{background:gold}

<div class="box1">....</div>
<div class="box2">....</div>
<div class="box3">....</div>

 

  6、伪类选择器

  常用的伪类选择器有hover,表示鼠标悬浮在元素上时的状态。

<style type="text/css">
    .box1:{width:100px;height:100px;background:gold;}
    .box1:hover{width:300px;}
</style>

 

三、浮动

  float 设置元素浮动,浮动可以让块元素排列在一行,浮动分为:

   左浮动:float:left;   右浮动:float:right;

   注:通常在实际的布局中,用到最多还是浮动,而不是定位,尽管定位实现起来更加不容易出错,但是确十分的麻烦--因为你需要获得知道每个块相对于父级块的位置,故我们做布局通常用浮动;这里总结一下:

  当块元素需要在同行显示时,我们考虑用浮动;而每个同行的块元素尽量给一个相同的父级,便于控制;

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>浮动</title>
    <style type="text/css">
        *{
            margin: 0px;
            padding: 0px;
        }
        .box{
            width: 1200px;
            height: 500px;
            /*background-color: #666;*/
            margin: 20px auto;
        }
        .leftbox{
            width: 900px;
            height: 500px;
            /*background-color: yellow;*/
            float: left;
        }
        .rightbox{
            width: 280px;
            height: 500px;
            background: lightblue;
            float: right;
        }

        .box1,.box2{
            width: 900px;
            height: 240px;
            background: yellow;
        }
        .box2{
            margin-top: 20px;
        }

    </style>
</head>
<body>
    <div class="box">
        <div class="leftbox">
            <div class="box1"></div>
            <div class="box2"></div>
        </div>
        <div class="rightbox"></div>
    </div>
</body>
</html>
浮动

 

四、定位  

  文档流 
 文档流,是指盒子按照html标签编写的顺序依次从上到下,从左到右排列,块元素占一行,行内元素在一行之内从左到右排列,先写的先排列,后写的排在后面,每个盒子都占据自己的位置。

  关于定位 
 我们可以使用css的position属性来设置元素的定位类型,postion的设置项如下:

 

   relative -- 生成相对定位元素,一般是将父级设置相对定位,子级设置绝对定位,子级就以父级作为参照来定位,否则子级相对于body来定位。

  absolute -- 生成绝对定位元素,元素脱离文档流,不占据文档流的位置,可以理解为漂浮在文档流的上方,相对于上一个设置了定位的父级元素来进行定位,如果找不到,则相对于body元素进行定位。  

  fixed--生成固定定位元素,元素脱离文档流,不占据文档流的位置,可以理解为漂浮在文档流的上方,相对于浏览器窗口进行定位。

 

  定位元素的偏移 
 定位的元素还需要用left、right、top或者bottom来设置相对于参照元素的偏移值。

  定位元素层级 
 定位元素是浮动的正常的文档流之上的,可以用z-index属性来设置元素的层级

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>定位</title>
    <style type="text/css">
        .bigbox{
            width: 400px;
            height: 400px;
            background: yellow;
            position: relative;
        }
        .box1{
            width: 200px;
            height: 200px;
            background: green;
            float: left;
            position: absolute;
            left: 400px;
            top: 400px;
            z-index: 10;

        }
        .box2{
            width: 200px;
            height: 1000px;
            background: blue;
            float: left;
            position: absolute;
            left: 600px;
            top: 600px;
            z-index: 11;
            opacity: 0.7;
        }
        .box3{
            width: 100px;
            height: 100px;
            background: red;
            position: fixed;
            right: 10px;
            top: 300px;
        }
    </style>
</head>
<body>

    <div class="bigbox">
        <div class="box1"></div>
        <div class="box2"></div>
        <div class="box3"></div>
    </div>

</body>
</html>
定位

 

五、CSS显示特性-display

 display属性是用来设置元素的类型及隐藏的,常用的属性有:
  1、none 元素隐藏且不占位置
  2、inline 元素以行内元素显示
  3、block 元素以块元素显示

 

六、CSS元素溢出  

  当子元素的尺寸超过父元素的尺寸时,需要设置父元素显示溢出的子元素的方式,设置的方法是通过overflow属性来设置。

overflow的设置项: 

  1、visible 默认值。内容不会被修剪,会呈现在元素框之外。
  2、hidden 内容会被修剪,并且其余内容是不可见的。
  3、scroll 内容会被修剪,但是浏览器会显示滚动条以便查看其余的内容。
  4、auto 如果内容被修剪,则浏览器会显示滚动条以便查看其余的内容。

  通常用于动画效果。

 

七、CSS权重

  CSS权重指的是样式的优先级,有两条或多条样式作用于一个元素,权重高的那条样式对元素起作用,权重相同的,后写的样式会覆盖前面写的样式。

 权重的等级:

 可以把样式的应用方式分为几个等级,按照等级来计算权重
  1、内联样式,如:style=””,权重值为1000
  2、ID选择器,如:#content,权重值为100
  3、类,伪类,如:.content、:hover 权重值为10
  4、标签选择器,如:div、p 权重值为1

<style type="text/css">

    body #content .main_content h2{
        color:red;    
    }

    #content .main_content h2{
        color:blue;
    }
</style>
......
<div id="content">
    <div class="main_content">
        <h2>这是一个h2标题</h2>
    </div>
</div>
<!-- 
第一条样式的权重计算: 1+100+10+1,结果为112;
第二条样式的权重计算: 100+10+1,结果为111;
h2标题的最终颜色为red
-->

 

   over~~~关于css样式就介绍这些可能用得着的,关于样式属性可以参考W3School手册  ---   http://www.w3school.com.cn/

 

posted @ 2018-08-17 22:15  Little_five  阅读(224)  评论(0编辑  收藏  举报