CSS基础学习

news2025/1/11 14:02:00

HTML+CSS+JavaScript
结构+表现+交互
学习内容:

  1. CSS是什么
  2. CSS怎么用(快速入门)
  3. CSS选择器(重点+难点)
  4. 美化网页(文字,阴影,超链接,列表,渐变…)
  5. 盒子模型
  6. 浮动
  7. 定位
  8. 网页动画(特效效果)

1. 是什么

Cascading Style Sheet 层叠级联样式表
CSS:表现(美化网页)
字体、颜色、边距、高度、宽度、背景图片、网页定位、网页浮动…
发展史
CSS 1.0
CSS 2.0 DIV(块)+CSS,HTML与CSS结构分离的思想,网页变得简单、SEO
CSS 2.1 浮动、定位
CSS 3.0 圆角、阴影、动画… 、浏览器兼容性~

2. 快速入门

方法一:
规范:在head标签中使用<style>标签可以编写CSS代码;每一个声明,最好使用分号结尾。

语法:
选择器{
	声明1;
	声明2;
	声明3;
}
例如:
<style>
	h1{
		color:red;
	}
</style>

方法二:分离

  1. 建立一个style.css文件
  2. 将声明的代码写在其中(CSS代码)
  3. 然后在HTML代码中使用
    <link rel="stylesheet" href="..../style.css">
    引入CSS代码,实现html与css分离

CSS优势:

  1. 内容和表现分离
  2. 内容结构表现统一,可以实现复用(网站中其他网页可以使用这个CSS)
  3. 样式十分的丰富
  4. 建立使用独立于HTML的CSS文件
  5. 利用SEO,容易被搜索引擎收录!

CSS的三种导入方式:
1、行内样式:在标签元素中,编写一个style属性,编写样式即可
2、内部样式:在<head>标签内编写一个style属性,编写样式即可
3、外部样式:建立一个CSS文件,在里面编写样式,在<head>标签内使用<link> 标签调用CSS文件即可

文件结构:
		项目名:
				CSS:
					style.css
				index.html

优先级:就近原则,离代码近的优先被使用
拓展:外部样式的两种导入写法:

  • 链接式:<link>
  • 导入式:(CSS 2.1特有的)
<style>
	@import url("css/style.css");
</style>
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <!--内部样式-->
    <style>
        h1{
            color: green;
        }
    </style>

    <!--外部样式-->
    <!--连接式-->
    <link rel="stylesheet" href="css/style.css">
    <!--导入式-->
    <style>
        @import url("css/style.css");
    </style>
</head>
<body>

<!--优先级:就近原则-->

<!--行内样式:在标签元素中,编写一个style属性,编写样式即可-->
<h1 style="color:red;">我是标题</h1>

</body>
</html>

3. 选择器

作用:选择页面上的某一个元素或者某一类元素
基本选择器

  1. 标签选择器:会选择到页面上所有的这个标签的元素,格式:标签{ }
  2. 类选择器:可以多个标签归类,是同一个class,可以复用,格式:.class的名称{ }
    例如:
<head>
	<style>
		.qtf1{
			color:....;
		}
		.qtf2{
			color:....;
		}
	</style>
</head>
<body>
	<h1 class="qtf1">标题1</h1>
	<h1 class="qtf2">标题2</h1>
	<p class="qtf1">P标签</p>
</body>
  1. id选择器:id必须保证全局唯一!格式:#id名称{ }
<head>
	<style>
		#qtf1{
			color:....;
		}
	</style>
</head>
<body>
	<h1 id="qtf1">标题1</h1>
</body>

标签选择器、类选择器、id选择器优先级是固定的:id选择器>类选择器>标签选择器

层次选择器

  1. 后代选择器:在某个元素的后面
    例如:
	body p{
		background : red;
	}

效果:body后面所有P标签背景颜色都改变

  1. 子选择器:后面一代(儿子)
    例如:
	body>p{
		background : red;
	}

效果:body后面下一个层次的P标签背景颜色改变

  1. 相邻兄弟选择器:只有一个,同层次相邻(向下)
    例如:
<head>
	<style>
		.active+p{
			background : red;
		}
	</style>
</head>	
<body>
	<p>P0</p>
	<p class="active">P1</p>
	<p>P2</p>
	<p>P3</p>
</body>

效果:只有P2会变颜色,因为相邻向下一个P标签兄弟style改变

  1. 通用兄弟选择器:当前选中元素的向下的所有兄弟元素
    例如:
<head>
	<style>
		.active~p{
			background : red;
		}
	</style>
</head>	
<body>
	<p>P0</p>
	<p class="active">P1</p>
	<p>P2</p>
	<p>P3</p>
	<p>P4</p>
</body>

效果:P2、P3、P4背景颜色全部改变,同层向下P标签兄弟变色

写法效果
body p{}后代所有p标签
body>p{}后一代所有p标签
body+p{}兄弟下一个p标签
body~p{}兄弟后面所有p标签

结构伪类选择器
使用 : 叫做伪类选择器

<body>
	<h1>H1</h1>
	<p>P1</p>
	<p>P2</p>
	<p>P3</p>
	<ul>
		<li>L1</li>
		<li>L2</li>
		<li>L3</li>
	</ul>
</body>

更换ul的第一个子元素背景颜色:

	ul li:first-child{
			background:....;
	}

更换ul的最后一个子元素背景颜色:

	ul li:last-child{
			background:....;
	}

选中并更改P1元素:首先需要定位到P元素的父元素,然后再定位到P1元素,必须是P元素才生效!
法1:选中P元素父亲body下的全部元素的第二个元素P1

		p:nth-child(2){
            color: #ff0051;
        }

法二:选中P元素父亲body下的P元素的第一个元素P1

        p:nth-of-type(1){
            background: yellow;
        }

属性选择器(常用)
id+class结合~
格式:名称[属性名=属性值]{} 名称可以是各种选择器的标签,属性值是正则表达式
基础正则表达式

符号含义
=绝对等于
*=包含这个元素
^=以这个元素开头
$=以这个元素结尾

例如:
存在id属性的a标签元素:

a[id]{
	background:....;
}

id=first的a标签元素:

a[id=first]{
	background:....;
}

class中有links的a标签元素:

a[class*="links"]{
	background:....;
}

选中href中以http开头的a标签元素:

a[href^=http]{
	background:....;
}

4. 美化网页元素

为什么要美化网页?

  1. 有效的传递页面信息
  2. 美化网页,页面漂亮,才能吸引用户
  3. 凸显页面主题
  4. 提高用户的体验

span标签:重点要突出的字,使用span套起来

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        #title1{
            font-size: 50px;
        }
    </style>

</head>
<body>


欢迎学习<span id="title1">Java</span>

</body>
</html>

在这里插入图片描述

字体样式:
font-family字体
font-size 字体大小
font-weight 字体粗细
color 字体颜色
颜色:
#RGB(红绿蓝) 0~F
#RGBA(红绿蓝透明度) A:0~1
例:
color:rgb(0,255,0);(绿色)
color:rgba(0,255,0,0.5);(绿色)
可以合在一起写:font: oblique bolder 16px "楷体";依次是斜体、粗体、大小、字体;

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <!--
    font-family:字体
    font-size:字体大小 px像素
    font-weight:字体粗细
    color:字体颜色
    -->
    <style>
        body{
            font-family: "Arial Black" , 楷体 ;
            color: #a13d30;
        }
        h1{
            font-size: 50px;
        }
        .p1{
            font-weight: bold;
        }

    </style>

</head>
<body>

<h1>主题思想</h1>
<p class="p1">
    《鬼吹灯》的内在主题是崇尚理性与和谐。小说所描写的盗墓过程其实终究是一场人心的较量。在墓中,死人与活人斗,墓主用尽各种手段、计谋来阻挠盗墓者的入侵;其次,盗墓也是活人与活人之间的暗算,兄弟之间尔虞我诈,反目成仇。因此,“盗墓小说”在不断颠覆世界观的同时,也在拷问人类的价值观。同样,这种人心不古的景象能够带给当代人一种启示:保持平淡,不去追求浮华,保持内心的强大。 [17]
</p>
<p>
    一部成功的盗墓类小说不仅仅在于它给人们带来的惊悚刺激和冷知识的传播,还有对于道德人性的规劝。天下霸唱在介绍摸金校尉这一行当的时候曾一再强调“鸡鸣灯灭不摸金”“出了盗洞后要把土回填”等等“规矩”,细细想来,这些规矩也不无做人的道理,鸡鸣灯灭不摸金是提醒人们再大的财富也不如自己的生命自由重要;把土回填则让读者做人学会谨慎有始有终;摸金时“明器”不能一扫而空就是提醒人们要想到后来人的利益不要过于贪婪。作为盗墓类小说指导性的作品,《鬼吹灯》中对现实的思考同样影响到后人的创作,在后来的盗墓类小说中也宣扬了好人好报,勿存恶念的想法。
</p>
<p>
    Conservationist and author Gerald Durrell and Lee McGeorge first met in 1977; two years later they were married.By the time Durrell died in 1995 they had travelled the world together on numerous conservation expeditions and co-written two books: A Practical Guide for the Amateur Naturalist, and Durrell in Russia. In 1978, a year after they first met, Gerald Durrell wrote a love letter to his future wife.
</p>

</body>
</html>

在这里插入图片描述

文本样式:
text-align:center排版水平居中
text-indent:2em段落首行缩进2字符
height:300px
line-height:300px
行高和块的高度一致,就可以上下居中
text-decoration:underline下划线
text-decoration:line-through中划线
text-decoration:overline上划线
text-decoration:nonea标签去掉下划线
rertical-align:middle文本图片水平对齐

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <!--
    颜色:
        单词
        RGB 0~F
        RGBA A:0~1

    text-align:排版,居中
    text-indent: 2em;段落首行缩进

    height: 300px;
    line-height: 300px;
    行高, 和 块的高度一致,就可以上下居中

    text-decoration  上中下划线,链接标签去下划线
    -->
    <style>
        h1{
            color: rgba(0,255,255,0.9);
            text-align: center;
        }
        .p1{
            text-indent: 2em;
        }
        .p3{
            background: #134efc;
            height: 300px;
            line-height: 300px;
        }
        .l1{
            text-decoration: underline;
        }
        .l2{
            text-decoration: line-through;
        }
        .l3{
            text-decoration: overline;
        }
        a{
            text-decoration: none;
        }
    </style>

</head>
<body>

<a href="">123</a>
<p class="l1">123123123</p>
<p class="l2">123123123</p>
<p class="l3">123123123</p>

<h1>主题思想</h1>
<p class="p1">
    《鬼吹灯》的内在主题是崇尚理性与和谐。小说所描写的盗墓过程其实终究是一场人心的较量。在墓中,死人与活人斗,墓主用尽各种手段、计谋来阻挠盗墓者的入侵;其次,盗墓也是活人与活人之间的暗算,兄弟之间尔虞我诈,反目成仇。因此,“盗墓小说”在不断颠覆世界观的同时,也在拷问人类的价值观。同样,这种人心不古的景象能够带给当代人一种启示:保持平淡,不去追求浮华,保持内心的强大。 [17]
</p>
<p>
    一部成功的盗墓类小说不仅仅在于它给人们带来的惊悚刺激和冷知识的传播,还有对于道德人性的规劝。天下霸唱在介绍摸金校尉这一行当的时候曾一再强调“鸡鸣灯灭不摸金”“出了盗洞后要把土回填”等等“规矩”,细细想来,这些规矩也不无做人的道理,鸡鸣灯灭不摸金是提醒人们再大的财富也不如自己的生命自由重要;把土回填则让读者做人学会谨慎有始有终;摸金时“明器”不能一扫而空就是提醒人们要想到后来人的利益不要过于贪婪。作为盗墓类小说指导性的作品,《鬼吹灯》中对现实的思考同样影响到后人的创作,在后来的盗墓类小说中也宣扬了好人好报,勿存恶念的想法。
</p>
<p class="p3">
    Conservationist and author Gerald Durrell and Lee McGeorge first met in 1977; two years later they were married.By the time Durrell died in 1995 they had travelled the world together on numerous conservation expeditions and co-written two books: A Practical Guide for the Amateur Naturalist, and Durrell in Russia. In 1978, a year after they first met, Gerald Durrell wrote a love letter to his future wife.
</p>

</body>
</html>

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <!--
    水平对齐  参照物   a,b
    文本图片水平对齐   vertical-align: middle;
    -->
    <style>
        img,span{
            vertical-align: middle;
        }
    </style>

</head>
<body>

<p>
    <img src="images/a.PNG" alt="">
    <span>fsfdsfsfsdfsdfsfd</span>
</p>



</body>
</html>

在这里插入图片描述

阴影
text-shadow:阴影颜色 水平偏移 垂直偏移 阴影半径;
在这里插入图片描述
例如:

#price{
	text-shadow:#3cc7f5 10px -10px 2px;
}

超链接伪类:
a:link{color:....;}未访问的链接状态
a:visited{color:....;}已访问的链接状态
a:hover{color:....;}鼠标悬浮的链接状态
a:active{color:....;}鼠标按住未释放的链接状态

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        /*默认的颜色*/
        a{
            text-decoration: none;
            color: black;
        }
        /*鼠标悬浮的状态(只需要记住)*/
        a:hover{
            color: orange;
            font-size: 50px;
        }
        /*鼠标按住未释放的状态*/
        a:active{
            color: green;
        }
        /*text-shadow:阴影颜色,水平偏移,垂直偏移,阴影半径*/
        #price{
            text-shadow: dodgerblue 10px -10px 2px;
        }
    </style>
</head>
<body>

<a href="#">
    <img src="images/书.PNG" alt="">
</a>
<p>
    <a href="#">这个春天最美的遇见</a>
</p>
<p>
    <a href="">作者:独孤九剑</a>
</p>
<p id="price">
    ¥99
</p>

</body>
</html>

在这里插入图片描述

列表样式 ul li
list-style:
none 去掉圆点
circle 空心圆
decimal 数字
square 正方形
例如:

ul li{
	height:30px;
	list-style:none;
	text-indent:1em;
}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="css/style.css">
</head>
<body>

<div id="nav">
    <h2 class="title">全部商品分类</h2>
    <ul>
        <li>
            <a href="#">图书</a>
            <a href="#">音像</a>
            <a href="#">数字商品</a>

        </li>
        <li>
            <a href="#">家用电器</a>
            <a href="#">手机</a>
            <a href="#">数码</a>
        </li>
        <li>
            <a href="#">电脑</a>
            <a href="#">办公</a>
        </li>
        <li>
            <a href="#">家居</a>
            <a href="#">家装</a>
            <a href="#">厨具</a>

        </li>
        <li>
            <a href="#">服饰鞋帽</a>
            <a href="#">个性化妆</a>

        </li>
        <li>
            <a href="#">礼品箱包</a>
            <a href="#">钟表</a>
            <a href="#">珠宝</a>
        </li>
        <li>
            <a href="#">食品饮料</a>
            <a href="#">保健食品</a>
        </li>
        <li>
            <a href="#">彩票</a>
            <a href="#">旅行</a>
            <a href="#">充值</a>
            <a href="#">票务</a>
        </li>
    </ul>
</div>

</body>
</html>
#nav{
    width: 300px;
    background: #a0a0a0;
}

.title{
    font-size: 18px;
    font-weight: bold;
    text-indent: 1em;
    line-height: 35px;
    /*颜色,图片,图片位置,平铺方式*/
    background: red url("../images/下.PNG") 260px 7px no-repeat;
}
/*ul li*/
/*
list-style:
    none 去掉圆点
    circle 空心圆
    decimal 数字
    square 正方形
*/
/*ul{
    background: #a0a0a0;
}*/

ul li{
    height: 30px;
    list-style: none;
    text-indent: 1em;
    background-image: url("../images/右.PNG");
    background-repeat: no-repeat;
    background-position: 220px 0px;
}

a{
    text-decoration: none;
    font-size: 14px;
    color: #000;
}
a:hover{
    color: orange;
    text-decoration: underline;
}

在这里插入图片描述

背景(背景颜色、背景图片)
例如:

<style>
	div{
		width:1000px;
		height:700px;
		border:1px solid red;/*边框:粗细 实线 颜色*/
		background-image:url("....");/*背景图片,默认全部平铺*/
	}
	.div1{
		background-repeat:repeat-x;/*x轴平铺*/
	}
	.div2{
		background-repeat:repeat-y;/*y轴平铺*/
	}
	.div3{
		background-repeat:no-repeat;/*不平铺*/
	}
</style>

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

background:red url("....") 260px 7px no-repeat;颜色、图片、图片位置、平铺方式

background-image:url("....");
background-repeat:no-repeat;
background-position:220px 0px;

渐变:https://www.grabient.com

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <!--径向渐变,圆形渐变-->
    <style>
        body{
            background-color: #85FFBD;
            background-image: linear-gradient(45deg, #85FFBD 0%, #FFFB7D 100%);
        }
    </style>
</head>
<body>

</body>
</html>

在这里插入图片描述

5.盒子模型

在这里插入图片描述
margin:外边距
border:边框
padding:内边距

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        /*body总有一个默认的外边距,需要改margin: 0*/
        /*h1,ul,li,a,body{
            margin: 0;
            padding: 0;
            text-decoration: none;
        }*/
        /*border:粗细,样式,颜色*/
        #box{
            width: 300px;
            border: 1px solid red;
        }

        h2{
            font-size: 16px;
            background: #3cbda6;
            line-height: 30px;
            color: white;
        }

        form{
            background: #3cbda6;
        }
        div:nth-of-type(1) input{
            border: 3px solid black;
        }
        div:nth-of-type(2) input{
            border: 3px dashed #4d0b8c;
        }
        div:nth-of-type(3) input{
            border: 2px dashed #008c27;
        }
    </style>

</head>
<body>

<div id="box">
    <h2>会员登录</h2>
    <form action="#">
        <div>
            <span>用户名:</span>
            <input type="text">
        </div>
        <div>
            <span>密码:</span>
            <input type="text">
        </div>
        <div>
            <span>邮箱:</span>
            <input type="text">
        </div>
    </form>
</div>

</body>
</html>

在这里插入图片描述

边框:border:1px solid red;/*边框:粗细 实线 颜色*/

  1. 边框的粗细
  2. 边框的样式 solid:实线 dashed:虚线
  3. 边框的颜色

内外边距
外边距的妙用:居中元素
margin:0上下左右都为0
margin:0 1px上下为0 左右为1个像素
margin:0 1px 2px 3px上 右 下 左 顺时针旋转

盒子的计算方式:margin+border+padding+内容宽度(四部分)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <!--外边距的妙用:居中元素
    margin: 0 auto;
    -->
    <style>
        #box{
            width: 300px;
            border: 1px solid red;
            margin: 0 auto;
        }
        /*
        顺时针旋转
        margin:0 上下左右
        margin: 0 1px 上下 左右
        margin: 0 1px 2px 3px 上 右 下 左
        */
        h2{
            font-size: 16px;
            background: #3cbda6;
            line-height: 30px;
            color: white;
            margin: 0 1px;
        }

        form{
            background: #3cbda6;
        }
        input{
            border: 1px solid black;
        }
        div:nth-of-type(1){
            padding: 10px 2px;
        }
    </style>

</head>
<body>

<div id="box">
    <h2>会员登录</h2>
    <form action="#">
        <div>
            <span>用户名:</span>
            <input type="text">
        </div>
        <div>
            <span>密码:</span>
            <input type="text">
        </div>
        <div>
            <span>邮箱:</span>
            <input type="text">
        </div>
    </form>
</div>

</body>
</html>

在这里插入图片描述

圆角边框
border-radius:10px 10px 10px 10px;/*左上 右上 右下 左下*/
圆圈:圆角≥宽度一半(半径 width:\height:)
例如:

div{
	/*红色的圆圈*/
	width:100px;
	height:100px;
	background:red;
	border-radius:50px;
}
/*圆形头像*/
img{
	width:100px;
	height:100px;
	border-radius:50px;
}

margin:0 auto;居中的前提条件
要求:块元素;<div></div>
块元素有固定的宽度width height

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>


    <!--
    左上 右上 右下 左下, 顺时针方向
    -->
    <!--
    圆圈: 圆角 > 宽度一半(半径) 会变成圆圈
    -->
    <style>
        div{
            width: 100px;
            height: 100px;
            background: red;
            border-radius: 50px 50px 50px 50px;
        }
        img{
            margin-top: 100px;
            width: 100px;
            height: 100px;
            border-radius: 50px;

        }
    </style>

</head>
<body>

<div>
</div>

<img src="images/111.jpg" alt="">

</body>
</html>

在这里插入图片描述

6. 浮动

块级元素:独占一行
h1~h6 p div 列表…
行内元素:不独占一行
span a img strong…
行内元素可以被包含在块级元素中,反之,则不可以~

display
display:inline-block;
block,块元素
inline,行内元素
inline-block,是块元素,但是可以内联,在一行!
none,消失
作用:将 块元素->行内元素 或 将 行内元素->块元素
这个也是一种实现行内元素排列的方式,但是我们很多情况都是用float(浮动)

diplay练习:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <!--
    display
    block,块元素
    inline,行内元素
    inline-block,是块元素,但是可以内联,在一行!
    none,消失
    -->
    <style>
        div{
            width: 100px;
            height: 100px;
            border:1px solid red;
            display: inline;
        }
        span{
            width: 100px;
            height: 100px;
            border:1px solid red;
            display: inline-block;
        }
    </style>

</head>
<body>

<div>div块元素</div>
<span>span行内元素</span>

</body>
</html>

结果:
在这里插入图片描述

float:左右浮动
例:float:rightfloat:left
clear
clear: right;右侧不允许有浮动元素,如果有就自动排列到右侧浮动元素的下一行
clear: left;左侧不允许有浮动元素
clear: both;两侧都不允许有浮动元素
clear: none;

父级边框塌陷的问题
解决方案:

  1. 增加父级元素的高度(不建议使用)
    原理:将浮动的元素包含起来,无论怎么浮动,元素都包含在父级边框中。
  2. 增加一个空的div标签,清除浮动
    在父级元素里的所有元素后面增加!
    <div class="clear"></div>
    .clear{clear:both;margin:0;padding:0;}
  3. overflow
    在父级元素中增加一个 overflow:hidden;
  4. 父类添加一个伪类:after (最正规)
#father:after{
	content:'';
	display:block;
	clear:both;
}

练习:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>浮动</title>
    <link rel="stylesheet" href="css/style.css">
</head>
<body>
<div id="father">
    <div class="layer01"><img src="images/111.jpg" alt=""></div>
    <div class="layer02"><img src="images/a.PNG" alt=""></div>
    <div class="layer03"><img src="images/书.PNG" alt=""></div>
    <div class="layer04">
        浮动的盒子
    </div>
    <!--<div class="clear"></div>-->
</div>
</body>
</html>
div{
    margin: 10px;
    padding: 5px;
}
#father{
    border: 1px #000 solid;
    /*overflow: hidden;*/
}
#father:after{
    content: '';
    display: block;
    clear: both;
}
.layer01{
    border: 1px #F00 dashed;
    display: inline-block;
    float: left;
}
.layer02{
    border: 1px #00F dashed;
    display: inline-block;
    float: left;
}
.layer03{
    border: 1px #060 dashed;
    display: inline-block;
    float: right;
}
/*
clear: right;右侧不允许有浮动元素,如果有就自动排列到右侧浮动元素的下一行
clear: left;左侧不允许有浮动元素
clear: both;两侧都不允许有浮动元素
clear: none;
*/
.layer04{
    border: 1px #666 dashed;
    font-size: 12px;
    line-height: 23px;
    display: inline-block;
    float: right;
}
.clear{
    clear: both;
    margin: 0;
    padding: 0;
}

结果:
在这里插入图片描述

小结:

  1. 浮动元素后面增加空div,简单,代码中尽量避免空div
  2. 设置父元素的高度,简单,元素假设没有了固定的高度,就会被限制
  3. overflow:hidden(隐藏)/ scroll(滚动条),简单,下拉的一些场景避免使用
  4. 父类添加一个伪类:after(推荐),写法稍微复杂一点,但是没有副作用,推荐使用。

对比:

  • display 方向不可以控制
  • float 浮动起来的话会脱离标准文档流,所以要解决父级边框塌陷的问题~

scroll练习

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        #content{
            width: 200px;
            height: 150px;
            overflow: scroll;
        }
    </style>
</head>
<body>

<div id="content">
    <img src="images/111.jpg" alt="">
    <p>
        哈哈指一个人发出的笑声,高兴开心欢乐时的状态,抒发快乐的心情,表现一个人很开心快乐的状态。也指人通常用来开玩笑。人的一种笑声,表示高兴、开心、愉悦,也表示兴奋。
    </p>
</div>

</body>
</html>

结果:
在这里插入图片描述

7. 定位

  1. 相对定位

例如:

#first{
	border: 1px dashed #325436;
    background-color: #325436;
    position: relative;/*相对定位:上下左右*/
    top:-20px;
    left:20px;
}

position: relative;
top:
left:
bottom:
right:
相对于原来的位置,进行指定的偏移。
相对定位的话,它仍然在标准文档流中,原来的位置会被保留。

默认情况

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        div{
            margin: 10px;
            padding: 15px;
            font-size: 12px;
            line-height: 25px;
        }
        #father{
            border: 1px solid #666;
            padding: 0;
        }
        #first{
            border: 1px dashed #325436;
            background-color: #325436;
        }
        #second{
            border: 1px dashed #47527a;
            background-color: #47527a;
        }
        #third{
            border: 1px dashed #5a3546;
            background-color: #5a3546;
        }
    </style>

</head>
<body>

<div id="father">
    <div id="first">第一个盒子</div>
    <div id="second">第二个盒子</div>
    <div id="third">第三个盒子</div>
</div>

</body>
</html>

效果:
在这里插入图片描述
练习:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <!--相对定位
    相对于自己原来的位置进行偏移
    -->
    <style>
        body{
            padding: 20px;
        }
        div{
            margin: 10px;
            padding: 15px;
            font-size: 12px;
            line-height: 25px;
        }
        #father{
            border: 1px solid #666;
            padding: 0;
        }
        #first{
            border: 1px dashed #325436;
            background-color: #325436;
            position: relative;/*相对定位:上下左右*/
            top:-20px;
            left:20px;
        }
        #second{
            border: 1px dashed #47527a;
            background-color: #47527a;
        }
        #third{
            border: 1px dashed #5a3546;
            background-color: #5a3546;
            position: relative;
            bottom: -10px;
            right: 20px;
        }
    </style>

</head>
<body>

<div id="father">
    <div id="first">第一个盒子</div>
    <div id="second">第二个盒子</div>
    <div id="third">第三个盒子</div>
</div>

</body>
</html>

结果:
在这里插入图片描述
相对定位练习:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>

<style>
    a{
        font-size: 20px;
        font-family: 楷体;
        text-align: center;
        color: white;
        line-height: 100px;
        width: 100px;
        height: 100px;
        text-decoration: none;
        background-color: #facafa;
        display: block;/*变成块元素*/
    }
    a:hover{
        background-color: #134efc;
    }
    #father{
        border: 1px solid red;
        margin: 0 auto;
        padding: 5px;
        width: 300px;
        height: 300px;
    }
    .d2{
        position: relative;
        top:-100px;
        left: 200px;
    }
    .d4{
        position: relative;
        bottom: 100px;
        left: 200px;
    }
    .d5{
        position: relative;
        bottom: 300px;
        left: 100px;
    }
</style>

<body>

<div id="father">
    <a class="d1" href="#">链接1</a>
    <a class="d2" href="#">链接2</a>
    <a class="d3" href="#">链接3</a>
    <a class="d4" href="#">链接4</a>
    <a class="d5" href="#">链接5</a>
</div>

</body>
</html>

效果:
在这里插入图片描述

  1. 绝对定位

position:absolute;

  1. 没有父级元素定位的前提下,相对于浏览器定位
  2. 假设父级元素存在定位,我们通常会相对于父级元素进行偏移
  3. 在父级元素范围内移动

相对于父级或浏览器的位置,进行指定的偏移,绝对定位的话,它不在标准文档流中,原来的位置不会被保留。

练习

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        div{
            margin: 10px;
            padding: 15px;
            font-size: 12px;
            line-height: 25px;
        }
        #father{
            border: 1px solid #666;
            padding: 0;
            position: relative;
        }
        #first{
            border: 1px dashed #325436;
            background-color: #325436;
        }
        #second{
            border: 1px dashed #47527a;
            background-color: #47527a;
            position: absolute;
            right: 30px;
            top: -10px;
        }
        #third{
            border: 1px dashed #5a3546;
            background-color: #5a3546;
        }
    </style>

</head>
<body>

<div id="father">
    <div id="first">第一个盒子</div>
    <div id="second">第二个盒子</div>
    <div id="third">第三个盒子</div>
</div>

</body>
</html>

结果:
在这里插入图片描述

  1. 固定定位

position:fixed;

固定在某一个位置,例如:网页中的“返回顶部”;

练习:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

    <style>
        body{
            height: 1000px;
        }
        div:nth-of-type(1){/*绝对定位:相对于浏览器*/
            width: 100px;
            height: 100px;
            background: red;
            position: absolute;
            right: 0;
            bottom: 0;
        }
        div:nth-of-type(2){/*fixed,固定定位*/
            width: 50px;
            height: 50px;
            background: yellow;
            position: fixed;
            right: 0;
            bottom: 0;
        }
    </style>

</head>
<body>

<div>div1</div>
<div>div2</div>

</body>
</html>

结果:
在这里插入图片描述

  1. z-index 层次

在这里插入图片描述
一层一层的结构,上层可以将下层覆盖
z-index:默认是0,最高无限~(999)
z-index:999;
z-index:1;
999的层次比1的高,因而显示在上面。

opacity:0.5;背景透明度

练习:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="css/style.css">
</head>
<body>

<div id="content">
    <ul>
        <li><img src="images/bg.PNG" alt=""></li>
        <li class="tipText">学习新思想,争做新青年</li>
        <li class="tipBg"></li>
        <li>时间:2099-01-01</li>
        <li>地点:月球一号基地</li>
    </ul>
</div>

</body>
</html>
#content{
    width: 208px;
    padding: 0;
    margin: 0;
    overflow: hidden;
    font-size: 12px;
    line-height: 25px;
    border: 1px black solid;
}
ul,li{
    padding: 0;
    margin: 0;
    list-style: none;
}
/*父级元素相对定位*/
#content ul{
    position: relative;
}
.tipText,.tipBg{
    position: absolute;
    width: 208px;
    height: 25px;
    top:17px;
}
.tipBg{
    background: black;
    /*opacity: 0.5;!*背景透明度*!*/
}
.tipText{
    z-index: 999;
    color: white;
}

运行结果:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/179399.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于电压型磁链观测器的异步电机矢量控制学习

导读&#xff1a;本期主要介绍电压型磁链观测器&#xff08;voltage flux observer&#xff09;在静止坐标系下的表现形式&#xff0c;应用在异步电机矢量控制系统中。如需要文中的仿真模型&#xff0c;关注微信公众号&#xff1a;浅谈电机控制&#xff0c;获取。一、引言磁链估…

万字长文--详解Node.js(快速入门)

Node.js基础与扩展Node.js1、初识Node.js与内置模块1.1 Node.js初识1.2 fs文件系统模块1.3 path路径模块1.4 http模块2、模块化2.1 模块化的基本概念2.2 Node.js中模块化2.3 npm与包2.4 模块的加载机制3、Express3.1 初识Express3.2 Express路由3.3 Express中间件3.4 使用Expre…

LeetCode刷题复盘笔记—一文搞懂贪心算法之45. 跳跃游戏 II问题(贪心算法系列第五篇)

今日主要总结一下可以使用贪心算法解决的一道题目&#xff0c;45. 跳跃游戏 II 题目&#xff1a;45. 跳跃游戏 II Leetcode题目地址 题目描述&#xff1a; 给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度…

论文投稿指南——中文核心期刊推荐(铁路运输)

【前言】 &#x1f680; 想发论文怎么办&#xff1f;手把手教你论文如何投稿&#xff01;那么&#xff0c;首先要搞懂投稿目标——论文期刊 &#x1f384; 在期刊论文的分布中&#xff0c;存在一种普遍现象&#xff1a;即对于某一特定的学科或专业来说&#xff0c;少数期刊所含…

Windows卸载与清除工具“ Geek 与 CCleaner ” (带你快速了解)

&#x1f4dc; “作者 久绊A” 专注记录自己所整理的Java、web、sql等&#xff0c;IT技术干货、学习经验、面试资料、刷题记录&#xff0c;以及遇到的问题和解决方案&#xff0c;记录自己成长的点滴。 &#x1f341; 操作系统【带你快速了解】对于电脑来说&#xff0c;如果说…

什么是闭包,Python闭包

闭包&#xff0c;又称闭包函数或者闭合函数&#xff0c;其实和前面讲的嵌套函数类似&#xff0c;不同之处在于&#xff0c;闭包中外部函数返回的不是一个具体的值&#xff0c;而是一个函数。一般情况下&#xff0c;返回的函数会赋值给一个变量&#xff0c;这个变量可以在后面被…

剑指 Offer 第5天、第6天

目录 剑指 Offer 04. 二维数组中的查找 剑指 Offer 50. 第一个只出现一次的字符 剑指 Offer 11. 旋转数组的最小数字 剑指 Offer 32 - I. 从上到下打印二叉树 剑指 Offer 32 - II. 从上到下打印二叉树 II 剑指 Offer 32 - III. 从上到下打印二叉树 III 剑指 Offer 04. 二…

Java线程池应用实例

线程池的学习基本概念好处应用场景ThreadPoolExecutor实例理解&#xff1a;执行流程自定义线程池4大核心参数测试demo结论&#xff1a;ExecutorService常用方法思考获取ExecutorService代码示例ScheduleExecutorService常用获取方式如下ScheduledExecutorService常用方法如下:代…

Linux | 一文带你真正搞懂Linux中的权限问题

在Linux下你有多少权限呢❓一、权限的基本概念二、Linux上的用户分类2.1 超级用户与普通用户2.2 用户之间的切换2.3 文件访问者的分类2.4 用户与访问者之间的联系三、文件属性与访问权限3.1 Linux下的文件类型&#xff08;1&#xff09;文件的八种类型&#xff08;2&#xff09…

单机Eureka构建步骤

目录 一、Eureka基础知识 &#xff08;一&#xff09;什么是服务治理 &#xff08;二&#xff09;什么是服务注册 &#xff08;三&#xff09;Eureka两组件 二、单机Eureka构建步骤 &#xff08;一&#xff09;IDEA生成eurekaServer端服务注册中心 &#xff08;二&#…

JavaWeb好用的工具、快捷键以及简单语法

一、VSCode ! tab生成一组默认页面模板lorem tab自动的生成一段随机的单词列模式编辑&#xff0c;将光标放在某个位置&#xff0c;然后按住alt&#xff0c;通过鼠标左键点击&#xff0c;就能选中多个位置一起修改/添加div.类名 tab可以直接创建一个类名为自己设定的块级元素…

前端布局神器display:flex

Flexbox&#xff0c;一种CSS3的布局模式&#xff0c;也叫做弹性盒子模型&#xff0c;用来为盒装模型提供最大的灵活性。首先举一个栗子&#xff0c;之前我们是这样实现一个div盒子水平垂直居中的。在知道对象高宽的情况下&#xff0c;对居中元素绝对百分比定位&#xff0c;然后…

java多线程的使用

温故而知新 --- Java多线程1. 关键字1.1 并发与并行1.2 进程和线程2. Java 线程2.1 Java的主线程2.2 线程声明周期3. Java 线程三种实现1.1 Big Data -- Postgres3. Java 线程三种实现1.1 Big Data -- Postgres4. Awakening1.1 Big Data -- Postgres1. 关键字 1.1 并发与并行 …

【图卷积网络】02-谱域图卷积介绍(一)

注&#xff1a;本文为第2章谱域图卷积介绍视频笔记&#xff0c;仅供个人学习使用 目录1、图卷积简介1.1 图卷积网络的迅猛发展1.2 回顾&#xff0c;经典卷积神经网络已在多个领域取得成功1.3 两大类数据1.4 经典卷积神经网络的局限&#xff1a;无法处理图数据结构1.5 将卷积扩展…

Linux查看本机状况命令

1.ip addr 查看自己的网络地址&#xff0c;网卡等情况 ping:查看网络可用性 2.top 查看当前计算机的cpu运行状况 在top状态下按1&#xff0c;可以查看自己的cpu是几核的 &#xff08;下图中红框的值是空闲率&#xff0c;用100-空闲率就是CPU使用率&#xff0c;单位为%&…

sql调优相关

目录 1.调优步骤 2.小表驱动大表 3.order by 优化 4.group by优化 1.调优步骤 慢查询的开启并捕获explain慢SQL分析show profile查询SQL在Mysql服务器里面的执行细节和生命周期情况SQL数据库服务器的参数调优 2.小表驱动大表 EXISTS SELECT ... FROM table WHERE EXISTS (su…

10. 好客租房-RocketMQ快速入门[非项目必需]

本章节主要是学习RocketMQ, 目标快速入门, 能够回答或解决以下问题:了解什么是RocketMQ了解RocketMQ的核心概念动手安装RocketMQ服务快速入门&#xff0c;掌握RocketMQ的api使用对producer、consumer进行详解了解RocketMQ的存储特点10.1 RocketMQ简介与安装10.1.1 核心概念速通…

分享143个ASP源码,总有一款适合您

ASP源码 分享143个ASP源码&#xff0c;总有一款适合您 下面是文件的名字&#xff0c;我放了一些图片&#xff0c;文章里不是所有的图主要是放不下...&#xff0c; 143个ASP源码下载链接&#xff1a;https://pan.baidu.com/s/1Fd3_qaHDj2_BuslyFT8YVQ?pwdrjmi 提取码&#x…

数据库02_函数依赖,范式---软考高级系统架构师008

1.首先我们来看这个,给定一个X,能确定一个Y那么就说,X确定Y,或者Y依赖x,那么 比如y = x * x 就是x确定y,或者y依赖于x 2.然后再来看图,那么左边的部分函数依赖,就是,通过A和B能决定C,那么如果A只用给就能决定C,那么就是部分函数依赖. 3.然后再来看,可以看到,A可以决定B,那么…

文件(2)

1)指定一个目录&#xff0c;扫描这个目录&#xff0c;找到当前目录下面所有文件的文件名是否包含了指定字符的文件&#xff0c;并提示这个用户是否要删除这个文件&#xff0c;根据用户的输入来决定是否删除&#xff1b; 1.1)需要进行输入一个目录&#xff0c;还需要进行输入一个…