CSS(3)

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 {	 /* IE6、7 专有 */
        *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 …
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值