css--2
2.盒子模型之margin
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>margin</title>
<style type="text/css">
.box1{
width:200px;
height: 200px;
background-color: rgba(217,163,141,0.83);
/*margin*/
/*margin-top:20px;*/
/*margin-left:20px;*/
/*margin-right:2px;*/
/*margin-bottom:20px;*/
/*简写,对应的个数匹配和border的一样*/
/*margin:20px 30px 40px 50px;*/
/*使盒子元素水平居中*/
margin: 0 auto;
}
/*垂直外边距
*/
.box2{
width:200px;
height: 200px;
background-color:chartreuse;
/*下面这个盒子的上边距如果小于上面盒子的下边距,默认为上面盒子的下边距
margin上下移动,对应的盒子也同步移动
*/
margin-top:20px;
border: 1px solid chartreuse;
}
.box2ch{
width: 50px;
height: 50px;
background-color: rgba(217,15,46,0.83);
margin-top: 30px;
}
/*span{*/
/*background-color: rgba(146,217,97,0.83);*/
/*}*/
/*!*设置两个不同的margin左右同步移动*!*/
/*.span1{*/
/*margin-left: 30px;*/
/*margin-right: 20px;*/
/*}*/
/*.span2{*/
/*margin-left: 20px;*/
/*}*/
/*总结
水平边距相遇时,不会发生重叠
垂直边距相遇时,会形成一个外边距,称为 外边距合并
注意,父子级盒子嵌套设置外边距合并,影响页面布局,
解决办法:给父元素添加一个border!
当两个垂直外边距 相遇时,会形成一个外边距 ,称为‘外边距合并'
所有毗邻的两个或更多盒元素的margin将会合并为一个margin共享之。毗邻的定义为:同级或者嵌套的盒元素,并且它们之间没有非空内容、Padding或Border分隔。
/*注意: 父子级盒子 嵌套 设置外边距 会形成外边距合并,影响页面布局,
解决办法: 子债父还
1. 父级或子元素使用浮动或者绝对定位absolute,浮动或绝对定位不参与margin的折叠
2. 父级overflow:hidden;
3. 父级设置padding(破坏非空白的折叠条件)
4. 父级设置border
*/
</style>
</head>
<body>
<div class="box1"></div>
<div class="box2">
<div class="box2ch"></div>
</div>
<!--<span class="span1">span1</span>-->
<!--<span class="span2">span2</span>-->
</body>
</html>
3.盒模型之padding
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>padding填充</title>
<style type="text/css">
.box1{
width:100px;
height:200px;
background-color: lightgreen;
padding-left: 20px;
padding-top: 20px;
padding-right: 20px;
padding-bottom: 20px;
}
</style>
</head>
<body>
<!--
内边框:内容区域到边框的距离
内边距会扩大会扩大元素所在的区域
注意:为元素设置内边距只能影响自己,不会影响其他的元素
-->
<div class="box1">padding</div>
<!--盒子模型计算尺寸
长:2 *(margin-left + margin-right + padding-left + padding-right) + width
宽:2 *(margin-top + margin-bottom + padding-top + padding-bottom) + height
-->
</body>
</html>
4.display属性
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>display</title>
<style type="text/css">
/*display属性
控制元素的显示和隐藏
块级元素与行内元素的转变
none 设置元素不会被显示
inline 元素会被显示为内联元素
block 元素会被显示为块级元素
inline-block 行内块元素
*/
div{
width:100px;
height:100px;
background-color: #A4D97B;
/*控制元素的隐藏,不占位置*/
/*display:none;*/
/*控制元素的隐藏,占位置,影响后面盒子的布局*/
/*visibility: hidden;*/
/*转换为行内块元素*/
display: inline-block;
/*转换为行内元素,行高等根据内容填充*/
display: inline;
}
a{
/*块级元素转换*/
display: inline-block;
width: 300px;
height: 300px;
background-color: #A4D97B;
}
img{
/*行内块元素一般和block进行转换,如果转换为行内元素没有意义*/
display: inline;
width:100px;
height: 100px;
}
</style>
</head>
<body>
<div>123</div>
<div>456</div>
<a href="#">百度一下</a>
<img src="https://g-search3.alicdn.com/img/bao/uploaded/i4/TB1d.RiRpXXXXaOapXX709V7VXX_014604.jpg_360x360Q90.jpg_.webp"
alt="华为">
</body>
</html>
5.浮动
浮动效果
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>浮动</title>
<style type="text/css">
*{
padding:0px;
margin:0px;
}
.wrap div{
width:200px;
height:200px;
border:1px solid black;
}
.box1{
background-color: red;
float: left;
}
.box2{
background-color: yellow;
margin-left: 20px;
}
.box3{
background-color: green;
}
.container{
/*width: 300px;*/
/*height: 300px;*/
background-color: rgba(229,107,40,0.83);
float:left;
}
span{
float:left;
background-color: aqua;
width: 100px;
height: 50px;
}
</style>
</head>
<body>
<!-- float浮动
left左浮动 左侧为起始、从左往右
right右浮动 右侧为起始、从右往左
文档流:可见元素在文档中排列位置
浮动产生的效果:
浮动可以使元素按指定位置排列,直到遇到父元素的边界或另一个元素的边界停止
浮动可以使元素脱离文档流,不占位置,
浮动会使元素提升层次
浮动可以使块元素在一行内排列不设置宽高时可以使元素适应内容
浮动可以使行内元素支持宽高
-->
<div class="wrap">
<div class="box1"></div>
<div class="box2"></div>
<div class="box3"></div>
</div>
<div class="container">哈哈</div>
<div class="container">哈哈</div>
<span>爽歪歪</span>
</body>
</html>
6.浮动产生的问题以及解决方案
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>浮动产生的问题以及解决方案</title>
<style type="text/css">
*{
padding: 0;
margin:0;
}
.wrap{
width:1190px;
/*通常页面布局的时候父盒子的高度不需要设置,
通过子盒子填充父盒子的高度*/
/*height: 500px;*/
background-color: red;
margin: 0 auto;
overflow: hidden;
}
.wrap div{
float:left
}
.wrap_1{
width:220px;
height: 480px;
background-color: yellow;
}
.wrap_2{
width:700px;
height: 480px;
background-color: green;
margin-left: 25px;
}
.wrap_3{
width:220px;
height: 480px;
background-color: blue;
margin-left: 25px;
}
/*#clearfix{*/
/*float: none;*/
/*clear:both;*/
/*}*/
/*官方推荐的解决浮动最常用的方法!*/
/*.wrap:after{*/
/*visibility:hidden;*/
/*clear:both;*/
/*display:block;*/
/*content:".";*/
/*height: 0;*/
/*}*/
</style>
</head>
<body>
<!--浮动产生的问题
父元素不设置高度时,子元素设置了浮动,子元素不占位置,不会撑开父原子的高度,
解决办法:
1.给父盒子设置固定高度,但是不灵活
2.给浮动元素最后一个加一个空的块级元素,且该元素不浮动float: none;
并设置clear:both; 但是结构冗余
3.官方推荐的解决浮动最常用的方法,给父元素添加伪元素!
如果页面中有定位元素,并超过了父级的范围,就必须使用clear属性来清除浮动来扩展盒子的高度。
.wrap:after{
visibility:hidden;
clear:both;
display:block;
content:".";
height: 0;
}
4.推荐使用!!!给父元素添加----在.wrap加一个 overflow:hidden;
-->
<div class="wrap">
<div class="wrap_1"></div>
<div class="wrap_2"></div>
<div class="wrap_3"></div>
<!--<div id="clearfix"></div>-->
</div>
</body>
</html>
案例学习,京东导航栏
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>京东导航栏练习</title>
<style type="text/css">
/*清除浏览器样式,否则影响布局*/
*{
padding: 0;
margin: 0;
}
.header{
width: 1000px;
height: 30px;
background-color: rgba(227,228,229,0.83);
font-family: 仿宋;
font-size: 15px;
margin:0 auto;
}
.header div,ul,li{
float:left;
line-height: 30px;
}
.header .list{
margin-left: 200px;
}
img{
width: 16px;
height: 16px;
margin-left: 40px;
margin-top:6px;
}
.header .myspan{
margin-left:10px;
}
.header .list a{
color: #281209;
text-decoration: none;
}
.header .list a:hover{
color: rgba(229,134,22,0.83);
}
#myul .seg:after{
content:"|";
}
</style>
</head>
<body>
<div class="header">
<div class="img">
<img id="img1" src="" alt="">
</div>
<div class="myspan"><span>路飞学城</span></div>
<div class="list">
<ul id="myul" type="none">
<li>你好,请登录 <a href="">登录</a></li>
<li class="seg"> </li>
<li><a href="#">我的京东</a></li>
<li class="seg"> </li>
<li><a href="#">京东会员</a></li>
<li class="seg"> </li>
<li><a href="#">企业采购</a></li>
<li class="seg"> </li>
<li><a href="#">客户服务</a></li>
<li class="seg"> </li>
<li><a href="#">网站导航</a></li>
<li class="seg"> </li>
<li><a href="#">手机京东</a></li>
</ul>
</div>
</div>
</body>
</html>
7.position定位
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>position的用法</title>
<style type="text/css">
*{
padding: 0;
margin: 0;
}
div{
width:200px;
height:200px;
}
.box1{
background-color: rgba(255,5,60,1);
position: relative;
top:20px;
left:40px;
}
.box2{
background-color:yellow;
}
.box3{
background-color: green;
position: absolute;
left: 40px;
top:10px;
}
.child{
width: 100px;
height: 100px;
background-color: red;
position: absolute;
left:10px;
}
</style>
</head>
<body>
<!--
overflow属性
visible 默认值。内容不会被修剪,会呈现在盒子之外
hidden 内容会被修剪,并且其余内容是不可见的
scroll 内容会被修剪,但是浏览器会显示滚动条一遍查看剩余内容
auto 如果内容被修剪,则浏览器会显示滚动条以便查看其余内容
-->
<!--position
大盒子一般用浮动,小盒子一般就用定位
position 的属性
static 默认值,没有定位
relative:
相对自身原来的位置进行偏移,用top left right bottom 进行设置单位px
不设定偏移量则本身没有变化
无论在标准流还是浮动流中,不会对父级元素和相邻元素有任何影响。
可以提升层级关系(会显示在最表面,不会被之前设置的元素遮盖)
absolute:
绝对定位,可以提升层级关系,脱离文档流
在没有父级父级元素定位时 定位!,以浏览器的左上角为基准
有父级的情况下,父级设置相对定位,子级设置绝对定位,是以父盒子进行定位的
“父相子绝对”
提升层级关系
脱离文档流
fixed :
固定定位,当浏览器精心滑动的时候,保持位置不变
-->
<div class="box1"></div>
<div class="box2"></div>
<div class="box3">
<div class="child"></div>
</div>
</body>
</html>
8.z-index
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>x-index</title>
<style type="text/css">
/*
border-radius,设置圆圈
*/
.box1{
width: 300px;
height: 300px;
background-color: rgba(255,5,60,1);
position: relative;
}
.children{
width: 100px;
height: 100px;
background-color: rgba(167,255,254,1);
position: absolute;
left: 100px;
top: 100px;
border-radius: 50%;
}
</style>
</head>
<body>
<!--
z-index定位处理 堆叠
z-index属性值:整数 默认值为0
设置了position属性时,z-index属性可以
设置各元素之间的重叠高地关系
z-index值大的层位于其值小的层上方
-->
<!--常见的网页布局
上下结构
上中下结构
上左右下结构 1-2-1结构
上左中右下结构 1-3-1结构
-->
<div class="box1">
<div class="children">
</div>
</div>
</body>
</html>