CSS:Cascading Style Sheet 层叠样式表
是一组样式设置规则,用于控制页面的外观样式
<head>
<style type="text/css">
选择器{
属性名:属性值;
属性名:属性值;
}
style>
head>
也称为CSS引用方式,有三种方式:内部样式、行内样式、外部样式
也称为内嵌样式,在页面头部通过style标签定义
对当前页面所有符合样式选择器的标签都起作用
也称为嵌入样式,使用HTML标签的style属性定义
只对设置style属性的标签起作用
使用单独的 css
文件定义,然后在页面头部中使用link标签引入外部样式表
<link rel="stylesheet" href="css样式文件的路径" type="text/css">
所有引入样式表文件的页面都起作用
步骤:
.css
文件.css
文件:
span{
color:green;
text-decoration: underline;
}
.html
文件:
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
<style>
p{
color:red;
font-size:50px;
}
style>
<link rel="stylesheet" href="css/style.css">
head>
<body>
<p>welcomep>
<div style="color: blue; font-weight: bold;">todiv>
<p>cssp>
<span>哈哈span>
body>
html>
CSS的注释形式:/**内容**/
注意:千万不要在style标签中写html的注释,如下
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
<style>
/*正确注释*/
p{
color:red;
font-size:50px;
}
style>
body>
html>
也称为元素选择器,使用HTML标签作为选择器名称
以标签名作为样式应用依据
使用自定义名称,以.
作为前缀,然后通过HTML标签的class属性调用类选择器
以标签的class属性值作为样式应用依据
注意:
调用时不能添加.
号
同时调用多个类选择器时以空格隔开
类选择器名称不能以数字开头
使用自定义名称,以#
作为前缀,然后通过HTML标签的id属性进行名称自动匹配
以标签的id属性值作为样式应用依据,一对一的关系
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
<style>
/*标签选择器*/
p{
color: red;
}
/*类选择器*/
.hello{
color: blue;
}
.world{
text-decoration: line-through;
}
/*ID选择器*/
#aaa{
background: #ccc;
}
style>
head>
<body>
<p id="aaa">嘿嘿p>
<div>哈哈div>
<span>嘻嘻span>
<p>吼吼p>
<div class="hello">YYdiv>
<ul>
<li class="hello world">Java开发li>
ul>
body>
html>
标签选择器和类选择器、标签选择器和ID选择器,一起使用
必须同时满足两个条件才能应用样式
也称为集体声明
将多个具有相同样式的选择器放在一起声明,使用逗号,
隔开
在某个选择器内再设置选择器,通过空格隔开
只有满足层次关系最里层的选择器所对应的标签才会应用样式
注:使用空格
时不区分父子还是后代,使用>
时必须是父子关系才行
根据不同的状态显示不同的样式,一般多用于a标签,即超链接
四种状态:
:link 未访问的链接
:visited 已访问的链接
:hover 鼠标移动到链接上,即悬浮在链接上
:active 选定的链接,被激活
要注意四种状态的书写顺序: link——> visited——>hover——>active
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
<style>
/*复合选择器:标签选择器和类选择器*/
p.hello{
color: red;
}
/*复合选择器:标签选择器和ID选择器*/
div#world{
color: blue;
}
/*组合选择器,也称为集体声明*/
.hello{
text-decoration: underline;
}
.world{
text-decoration: line-through;
}
div.abc{
text-decoration: overline;
}
.hello,.world,div.abc{
font-size: 20px;
font-weight: bold;
background: #cccccc;
}
/*嵌套选择器*/
div span{
font-style: italic;
}
/*伪类选择器*/
/*只能按照这种顺序书写,不能随便换顺序*/
a:link{
font-size: 12px;
color: red;
text-decoration: none;
}
a:visited{
font-size: 20px;
color: yellow;
text-decoration: none;
}
a:hover{
font-size: 30px;
color: blue;
text-decoration: none;
}
a:active{
font-size: 40px;
color: green;
text-decoration: none;
}
style>
head>
<body>
<p class="hello">welcomep>
<div id="world" class="abc">todiv>
<span class="hello">cssspan>
<p>hellop>
<div>
<span>嘿嘿span>
div>
<div>
<p>
<span>嘻嘻span>
p>
div>
<a href="test02.html">打开test02页面a>
body>
html>
行内样式 > ID选择器 > 类选择器 > 标签选择器
原因:首先加载标签选择器,再加载类选择器,然后加载ID选择器,最后加载行内样式
后加载的会覆盖先加载的同名样式
注:当样式不冲突时会全部加载,样式冲突时按选择器的优先级加载
就近原则
原因:按照书写顺序依次加载,在同优先级的前提下,后加载的会覆盖先加载的同名样式,所以离的越近越优先
可以使用!important
使某个样式属性具有最高的优先级
<style>
p{
color: red;
text-decoration: underline!important;
}
style>
定义字体相关的样式
属性 | 含义 | 说明 |
---|---|---|
font-size | 大小、尺寸 | 所有CSS属性的默认值都为inherit(继承父容器的大小) |
font-weight | 粗细 | 取值:normal、bold(粗体) |
font-family | 字体 | 取值:黑体、楷体等 |
font-style | 样式 | 取值:normal、italic(斜体) |
属性 | 含义 | 解释 |
---|---|---|
color | 颜色 | 使用英文单词、16进制的RGB值,特定情况下可以缩写,如#FFFFFF > #FFF |
line-height | 行高 | 行内容的高度,也可以简单的理解为行之间的距离 |
text-align | 水平对齐方式 | 取值:left、center、right |
vertica-lalign | 垂直对齐方式 | 取值:top、middle、bottom,可用于图片和文字的对齐方式 |
textdecoration | 文本修饰 | 取值:underline、overline、linethrough、none |
属性 | 含义 | 解释 |
---|---|---|
background-color | 背景颜色 | |
background-image | 背景图片 | 必须使用url(路径) |
background-repeat | 背景图片的重复方式 | 取值:repeat(默认)、repeat-x、repeat-y、no-repeat |
backgroundposition | 背景图片的显示位置 | 取值:关键字(top、bottom、left、right、center)、坐标 |
background | 简写 | 一般顺序:颜色 图片 重复方式 显示位置 |
<style>
p{
background-color: #ccc;
background-image: url(image/qq.jpg);
background-repeat: no-repeat;
background-position: center center;
background-position: 150px 50px;
background: #ccc url(image/qq.jpg) no-repeat 150px 50px;
}
style>
使用liststyle属性设置列表项前的标记
通过float属性实现元素的浮动,取值:
通过display属性设置元素是否显示,以及是否独占一行
常用取值:
注:行级元素默认无法设置宽和高,可以为行级元素设置display:inline-block,然后就可以设置宽和高
盒子模型是网页布局的基础,将页面中所有的元素都看作成一个盒子,盒子都包含以下几个属性:
表示盒子的边框
分为四个方向:上top、右right、下bottom、左left
每个边都包含三种样式:颜色color、粗细width、样式style
border-style的取值:solid实线、dashed虚线、dotted点状线、double双线等
简写,三种方式:
按方向简写
border-top、border-right、border-bottom、border-left
书写顺序,border-方向 : width style color
按样式简写
border-color、border-width、border-style、border-radius圆角
书写顺序,border-样式 : top right bottom left
必须按顺时针方向书写,即:上、右、下、左的顺序,同时可以缩写
border-width : 2px ——> 四个边的宽度都为2px
border-width : 2px 4px
border-width : 2px 3px 4px
注: 如果省略, 则认为上下一样、 左右一样
终极简写
如果四个边都一样,border : width style color
表示盒子的内边距,即内容与边框之间的距离
同样也分为四个方向,也可以简写(按顺时针方向、默认上下一样,左右一样)
表示盒子的外边距,即盒子与盒子之间的距离
同样也分为四个方向,也可以简写(按顺时针方向、默认上下一样,左右一样)
页面中的元素实际所占空间:
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
<style>
p{
width: 250px;
background: #cccccc;
}
.first{
border-top-width: 1px;
border-top-color: red;
border-top-style: solid;
/*简写*/
border-bottom: 4px dashed blue;
/*border-radius圆角,值为圆角的半径,举例:设置右下角*/
border-bottom-right-radius: 5px;
}
.second{
padding-left: 10px;
}
.third{
margin-top: 50px;
}
body{
border: 1px solid blue;
width: 260px;
}
style>
head>
<body>
<p class="first">welcome to cssp>
<p class="second">welcome to cssp>
<p class="third">welcome to cssp>
body>
html>
通过position属性实现对元素的定位,有四种定位方式
常用取值:
取值 | 含义 | 解释 |
---|---|---|
static | 默认值 | 按照常规文档流进行显示 |
relative | 相对定位 | 相对于标签原来位置进行的定位 |
absolute | 绝对定位 | 相对于第一个非static定位的父标签的定位 |
fixed | 固定定位 | 相对于浏览器窗口进行定位 |
设置定位方式后,还需要设置定位属性(偏移量):top、bottom、left、right
注:z-index 优先级属性,默认值为0,当两个元素有重叠时,优先级高的元素覆盖优先级低的元素,z-index属性只有对非static的元素设置才生效
先设置元素的position属性为relative,然后再设置偏移量
先设置父标签为非static定位,然后设置元素的position属性为absolute,最后再设置偏移量
注意事项:
先设置元素的position属性为fixed,然后再设置偏移量
注意事项:
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Titletitle>
<style>
#wrapper{
width: 800px;
border: 1px solid #ccc;
position: relative;
}
.d1,.d2,.d3{
width: 100px;
height: 100px;
}
.d1{
background: red;
position: relative; /*相对定位*/
top: 20px;
left: 50px;
z-index: 1;
}
.d2{
background: blue;
position: absolute;
top: 50px;
}
.d3{
background: green;
position: fixed;
top: 100px;
right: 50px;
}
style>
head>
<body>
<div id="wrapper">
<div class="d1">div1div>
<div class="d2">div2div>
<div class="d3">div3div>
div>
body>
html>