小米布局案例1:产品模块布局分析
类似于这样的产品模块,使用css+html布局来完成。
*{
margin: 0;
padding: 0;
}
body{
background-color: #f5f5f5;
}
.box{
width:1100px;
height:400px;
margin: 200px auto;
}
.box1{
width:200px;
height:350px;
background-color: white;
margin: 10px 10px 10px 20px;
display:inline-block;
padding: 10px;
overflow: hidden;
transition: all 1s;
}
.box1:hover{
transform: scale(1.07);
}
.box1 img{
width: 100%;
}
.box1 h5{
text-indent: 25px;
}
.box1 p{
font-family: 宋体;
font-size: 10px;
color: #9e9494;
margin-top: 20px;
}
.box1 h4{
font-family: 微软雅黑;
color:red;
margin-top: 20px;
text-indent: 2em;
float: left;
}
#lgprice{
margin-top: 20px;
color: #9e9494;
}
Redmi 红米电视 70英寸
70英寸震撼巨屏,4K画质,细腻如真
3429元
3117元
Redmi 红米电视 70英寸
70英寸震撼巨屏,4K画质,细腻如真
3429元
3117元
Redmi 红米电视 70英寸
70英寸震撼巨屏,4K画质,细腻如真
3429元
3117元
Redmi 红米电视 70英寸
70英寸震撼巨屏,4K画质,细腻如真
3429元
3117元
圆角边框
border-radius:length;//数值越大,越圆。可以跟四个值,顺时针方向。
border-top-left-radius:xxpx;//设置左上角。
盒子阴影
box-shadow:h-shadow v-shadow blur spread color inset;//严格按照顺序来写
值
描述
h-shadow
必须,水平阴影的部分,可以是负值。
v-shadow
必须,垂直阴影的部分,可以是负值。
blur
可选,模糊距离。
spread
可选,阴影尺寸的位置。
color
可选,阴影的颜色。
inset
可选,可将外部阴影改为内部阴影,但是默认outset但是没必要写 。
小米布局案例2:增加阴影效果
box-shadow: 10px 10px 10px rgba(0,0,0,0.3);
很明显阴影的效果会出来。
浮动
为什么需要浮动?
使用行内块会出现空隙。
网页布局的第一准则:多个块级元素纵向排列找标准流,多个块级元素横向排列找浮动。
什么是浮动?
float属性用于创建浮动窗,将其移到一边,直到左边缘或右边缘触及包含块或另一个浮动框的边缘。
浮动特性:
脱标,脱离标准普通流移动到指定的位置。
浮动的盒子不再保留原先的位置。
叠起来的感觉。
注意:
如果多个盒子都设置了浮动,则它们会按照属性值一行内显示并且顶端对齐。
浮动的元素是互相贴在一起的(没有缝隙)。如果父级宽度装不下这些浮动的盒子,多出的盒子会启另一行对齐。
浮动元素会具有行内块元素的特性
任何元素都可以浮动,不管原先是什么模式的元素,添加浮动之后具有行内块元素的特性。
浮动元素经常和标准流父级搭配使用
小米布局案例3:浮动布局
这个是小米官网的极简布局形式,可以使用浮动来实现。
案例:小米布局实例4:
这里主要实现它的布局模式。
有一个点要说到,那就是权重问题。
.box li{
width: 296px;
height: 285px;
background-color: white;
list-style: none;
margin-right: 14px;
float: left;
}
.box .last{
margin-right: 0;
}
我们这里的last的权重没有li高,所以使用
.last{
margin-right: 0;
}
是不可以解决问题的,或者给li绑定一个id属性,可以解决这个问题,加上.box也是可以的。
这个主要是父类的盒子装不下子类的容器,使用css层叠性去掉最后一个盒子不需要的属性。
小米布局案例5:浮动的综合学习。
浮动要注意的点
一个浮动,理论上所有的兄弟元素都要浮动。
浮动只会压住后面的标准流,不会压住前面的标准流。
先使用标准父元素排列上下位置,之后内部子元素采取浮动排列左右位置。
所有的父盒子都必须要有高度吗?
当子元素很多时候,不方便计算。
理想中的就是让子元素撑开父元素。
但是不可以,父盒子的兄弟盒子会跑上去。但可以使用清除浮动。
为什么要清除浮动
父级没高度。
子盒子浮动了。
影响下面布局了,我们就要清除浮动。
清除浮动
本质:清除浮动元素造成的影响。
如果父盒子本身有高度,则不需要清除浮动。
清楚浮动之后,父级就会根据浮动的子盒子自动检测高度,父级有了高度,就不会影响下面的标准流了。
语法:
选择器{clear:属性值;}
属性值
描述
left
清除左侧浮动的影响
right
清除右侧浮动的影响。
both
两侧都清除
下面这个案例就是没有给父类设置高度,虽然独占一行可以,但是变为一行的时候,下面的元素还是会挤上来。
如何去解决这个问题呢?
一般使用clear:both;
清除浮动的策略:
方法一:闭合浮动,使用
方法二:父级添加overflow
可以给父级添加overflow属性,将其属性设置为hidden、auto或scroll。
缺点:溢出隐藏
:after伪元素清除浮动。
双伪元素清除浮动。
.clearfix:before,.clearfix:after{
content:"";
display:table;
}
.clearfix:after{
clear:both;
}
.clearfix{
*zoom:1;
}
子元素
使用before和after关住盒子。
缺点:I6和I7不支持。
.clear{
clear:both;
}
这个方法叫做额外标签法,同时被称为“隔墙法”。但是
注意:这个元素必须是块级元素,不能是行级元素。
Document.left{
float: left;
width: 100px;
height: 100px;
background-color: blueviolet;
}
.right{
float: left;
width: 100px;
height: 100px;
background-color: rgb(53, 47, 58);
}
.box2{
width: 500px;
height: 200px;
background-color: brown;
}
.clear{
clear:both;
}
这是我看的pink老师讲的html和css的进阶部分的学习笔记,这部分是有关父元素以及子元素浮动的内容 ,讲的非常好,由于以前学过这部分的知识,所以有的部分写的比较简单或者遗漏的,希望大家见谅。
最后完结时我会将这部分笔记以及后面的实例上传到github,希望大家指正,共同学习。