本篇主要介绍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="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{100px;height:100px;background:gold} ...... <div class="blue">....</div> <h3 class="blue big box">....</h3> <p class="blue box">....</p>
3、层级选择器
主要应用在标签嵌套的结构中,层级选择器,是结合上面的两种选择器来写的选择器,它可与标签选择器结合使用,减少命名,同时也可以通过层级,限制样式的作用范围。
.con{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{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/