CSS3新增
1. 圆角边框
border-radius:length;
border-top-left-radius: 左上角的弧度
border-top-right-radius: 右上角的弧度
border-bottom-right-radius: 右下角的弧度
border-bottom-left-radius : 左下角的弧度
参数值可以是 数值 或 百分比 的形式。
50%就是宽度和高度的一半=100px
2. 盒子阴影
box-shadow: h-shadow(必需,水平阴影,允许负值) v-shadow(必需,垂直阴影,允许负值) blur(可选,模糊距离) spread(可选,阴影尺寸) color(可选) inset(可选,将外部阴影改为内阴影)
文字阴影:text-shadow
3. 浮动
CSS提供三种传统布局方式:
普通流(标准流):---按照标签规定好的默认排列方式:
-块级元素会独占一行,从上向下顺序排列; 常用元素:div、hr、p、h1~h6、ul、ol、dl、form、table
-行内元素会按照顺序,从左到右顺序排列,碰到父元素边缘则自动换行; 常用元素:span、a、i、em等
浮动:--- 多个块级元素纵向排列找标准流,
多个块级元素**纵向**排列找**标准流**, 多个块级元素**横向**排列找**浮动**。}
选择器 { float: 属性值; }
none 不浮动(默认值)
left 向左浮动
right 向右浮动
浮动特性:
-脱离标准普通流的控制,移动到指定位置(俗称脱标)
-浮动的盒子不再保留原先的位置。
-如果多个盒子都设置了浮动,则它们会按照属性值---行内显示并且顶端对齐排列
-具有**行内块元素**的特性
注意点:
-浮动和标准流的父盒子搭配
(先用标准流的父元素排列上下位置,之后内部子元素采取浮动排列左右位置)
-一个元素浮动了,理论上其余的兄弟元素也要浮动。
(浮动只会影响当前的或者是后面的标准流盒子,不会影响前面的标准流。)
清除浮动:
-因为父级盒子很多情况下,不方便给高度,但是子盒子浮动就不占有位置,最后父级盒子高度为0,就影响了下面的标准流盒子。
-由于浮动元素不再占用原文档流的位置,所以它会对后面的元素排版产生影响
清除浮动本质:---清除浮动元素脱离标准流造成的影响
清除浮动之后, 父级就会根据浮动的子盒子自动检测高度。父级有了高度,就不会影响下面的标准流了}
选择器 { clear: 属性值; }
left 不允许左侧有浮动元素(清除左侧浮动的影响)
right 不允许右侧有浮动元素(清除右侧浮动的影响)
both 同时清除左右两侧浮动的影响(常用)
额外标签法[隔墙法]: 是W3C推荐的做法
在浮动元素末尾添加一个额外标签<div style=”clear:both”></div>,或则其他标签<br/>等亦可。
优点:通俗易懂,书写方便
缺点:添加许多无意义的标签,结构化较差。
父级添加 overflow: hidden| auto| scroll 属性方法
优点: 代码简洁
缺点:无法显示需要溢出的元素。
父级添加 [:after] 伪元素}
.clearfix:after {
content: "";
display: block;
height: 0;
clear: both;
visibility: hidden;
}
<div class="box clearfix"></div>
.clearfix {
*zoom: 1;
}
优点:符合闭合浮动思想 结构语义化正确
缺点:照顾低版本浏览器
代表网站:网易、阿里
父级添加 双伪元素}
.clearfix:before,
.clearfix:after {
content: "";
display: table;
}
.clearfix:after {
clear: both;
}
.clearfix {
*zoom: 1;
}
<div class="box clearfix"></div>
优点: 代码更简洁
缺点:照顾低版本浏览器
代表网站:小米、腾讯等
定位:
定位:---将盒子「定」在某一个「位」置 自由的漂浮在其他盒子(包括标准流和浮动)的上面。
定位 = 定位模式(用于指定一个元素再文档中的定位方式) + 边偏移(决定了该元素的最终位置)
定位模式(position):通过CSS的 position 属性来设置。}
选择器 { position: 属性值; }
值 语义
static 「静态」定位
relative 「相对」定位
absolute 「绝对」定位
fixed 「 固定」定位
静态定位(static)[了解]:
静态定位 按照标准流特性摆放位置。它没有边偏移。
静态定位在布局时很少使用。
相对定位(relative):---相对定位是元素相对原来自身的位置。(给绝对定位当爹的)
-相对于自己原来在位置来移动的(移动位置的时候参照点是自己原来的位置)。
-原来在标准流的位置继续占有,后面的盒子仍然以标准流的方式对待它。(不脱标,继续保留原来位置)
绝对定位(absolute):---元素在移动位置的时候,是相对于它祖先元素来说的(拼爹型)。
-如果没有祖先元素或祖先元素没有定位,则以浏览器为准定位(Document文档)。
-如果祖先元素有定位(相对、绝对、固定定位),则以最近一级的有定位祖先元素为参考点移动位置。
-绝对定位不再占有原先的位置(脱标)
【子绝父相】
固定定位(fixed):---元素固定于浏览器可视区的位置。(可以在浏览器页面滚动时元素的位置不会改变)
-以浏览器的可视窗口为参照点移动元素
跟父元素没有任何关系;单独使用
不随滚动条滚动
-固定定位不再占有原先的位置(脱标)
粘性定位(sticky)[了解]:
以浏览器的可视窗口为参照点移动元素
粘性定位占有原先的位置
必须添加top、left、right、bottom其中一个才有效
兼容性较差,IE不支持
边偏移:有top、bottom、left 和 right 4个属性。
边偏移属性 示例 描述
top top: 80px 「顶端」偏移量,定义元素相对于其父元素「上边线的距离」。
bottom bottom: 80px 「底部」偏移量,定义元素相对于其父元素「下边线的距离」。
left left: 80px 「左侧」偏移量,定义元素相对于其父元素「左边线的距离」。
right right: 80px 「右侧」偏移量,定义元素相对于其父元素「右边线的距离」
定位叠放次序(z-index):
在使用定位布局时,可能会出现盒子重叠的情况。此时,可以使用z-index来控制盒子的前后次序(z轴)
数值可以是正整数、负整数或 0,默认值是 0,数值越大,盒子越靠上;
如果属性值相同,则按照书写顺序,后来居上;
数字后面不能加单位
只有定位的盒子才有z-index属性
拓展:
绝对定位的盒子居中:
绝对定位/固定定位的盒子不能通过设置margin: auto水平居中,可以按照下面的方法实现水平居中和垂直居中:
left : 50%:让盒子的左侧移动到父级元素的水平中心位置;
margin-left: -100px;让盒子向左移动自身宽度的一半。
同理垂直居中。
绝对定位和固定定位也和浮动类似。
行内元素添加绝对或者固定定位,可以直接设置高度和宽度。
块级元素添加绝对或者固定定位,如果不给宽度和高度。默认大小是内容的大小
绝对(固定定位)会完全压住盒子。
浮动只会压住它下面标准流的盒子,但不会压住下面标准流盒子里面的文字(图片)---产生的目的为了做文字环绕效果的
元素的显示与隐藏
display:显示模式---隐藏之后,不再占有原来的位置。
display: none 隐藏对象【重点】
display: block 除了转换为块级元素之外,同时还有显示元素的意思。
visibility:显示隐藏---隐藏之后,继续占有原来的位置
visibility:visible 元素可视
visibility:hidden 元素隐藏
overflow: 溢出显示隐藏---对于溢出的部分处理
属性值 描述
visible 不剪切内容也不添加滚动条
hidden 不显示超过对象尺寸的内容,超出的部分隐藏掉(有定位盒子,谨慎使用)
scroll 不管超出内容否,总是显示滚动条
auto 超出自动显示滚动条,不超出不显示滚动条
CSS属性书写顺序:
建议遵循以下顺序:
布局定位属性:display / position / float / clear / visibility / overflow(建议 display 第一个写,毕竟关系到模式)
自身属性:width / height / margin / padding / border / background
文本属性:color / font / text-decoration / text-align / vertical-align / white- space / break-word
其他属性(CSS3):content / cursor / border-radius / box-shadow / text-shadow / background:linear-gradient …