爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
HTML教程
{{CSS}}浮动跟定位
{{CSS}}浮动跟定位
日期:2014-05-17 浏览次数:21291 次
{{CSS}}浮动和定位
1.浮动
float:left|right|none|inherit
初始值:none
应用于:所有元素
继承性:无
1)浮动元素
对于浮动元素有以下几点需注意。首先,会以某种方式将浮动元素从文档的正常流中删除,不过它还是会影响布局。即一个元素浮动时,其他内容会“环绕”该元素。
2)不浮动
float:none用于防止元素浮动。
3)浮动规则
首先,需要建立包含块(containing block)的概念。浮动元素的包含块是其最近的块级祖先元素。
其次,浮动元素会生成一个块级框,而不论这个元素本身是什么,即使该元素是行内元素。此时对浮动元素声明display:block;是不必要的。
最后,讨论控制着浮动元素摆放的规则。
1.浮动元素的左(或右)外边界不能超出其包含块的左(或右)内边界。
2.浮动元素的左(或右)外边界必须是源文档中之前出现的左浮动(或右浮动)的元素的右(左)外边界,除非后出现浮动元素的顶端在先出现浮动元素的底端的下面。这条规则可以防止浮动元素彼此“覆盖”。
3.左浮动元素的右外边界不会在其右边浮动元素的左外边的右边。同理,一个右浮动元素的左外边界不会在其左边任何浮动元素的右外边界的左边。这条规则可以防止浮动元素相互重叠。
4.一个浮动元素的顶端不能比其父元素的内顶端更高。如果一个浮动元素在两个合并外边距之间,放置这个浮动元素时就好像在两个元素之间有一个块级元素。
5.浮动元素的顶端不能比之前所有浮动元素或块级元素的顶端更高。
6.如果源文档中一个浮动元素之前出现另一个元素,浮动元素的顶端不能比包含该元素所生成框的任何行框的顶端更高。
7.左(或右)浮动元素的左边(右边)有另一个浮动元素,前者的右边外边界不能在其包含块的右(左)边界的右边(左边)。这就是说,浮动元素不能超出其包含元素的边界,除非它太宽,本身无法放下。
8.浮动元素必须改可能高地放置。
9.左(右)浮动元素必须向左(右)尽可能远。位置越高,就会向右或向左浮动的越远。
4)负外边距
负外边距可能导致浮动元素移到其父元素的外面。(这并不违返浮动规则)
5)浮动元素,内容和重叠
若一个浮动元素与正常流中的内容发生重叠,其遵守以下规则:(CSS2.1指明)
1.行内框与一个浮动元素重叠时,其边框,背景和内容都在该浮动元素“之上”显示
2.块框与一个浮动元素重叠时,其边框和背景在该浮动元素“之下”显示,而内容在浮动元素“之上”显示
6)清除
clear:left|right|both|none|inherit
初始值:none
应用于:块级元素
继承性:无
在CSS1/2中,clear工作如下,它会增加元素的上外边距,使之最后落在浮动元素的下面,这实际上会忽略为清除元素(设置了clear的元素)顶端位置的外边距宽度,即清除元素的上外边距可能会调整。
在CSS2.1中,引入了一个清除区域。清除区域是在元素上外边距之上增加的额外间隔,不允许任何浮动元素进入这个范围,即元素设置了clear属性时,它的外边距并不改变。
2.定位
利用定位,可以准确地定义元素框相对于其正常位置应该出现在哪里,或相对于其父元素,另一个元素,或视口本身。
position:static|relative|absolute|fixed|inherit
初始值:static
应用于:所有元素
继承性:无
position的值的含义:
static: 元素框正常生成。块级元素生成一个矩形框,作为文档流的一部分,行内元素则会创建一个或多个行框,置于其父元素中。
relative: 元素框偏移某个距离,元素仍保持其定位前的形状,它原本所占的空间仍保留。
absolute: 元素框从文档流中删除,并相对于某包含块定位。元素定位后生成一个块级框。
fixed: 元素框的表现类似于position:absolute;,但其包含块为视口。
1)包含块
对于定位,包含块定义为:
“根元素”的包含块(也称为初始包含块)由用户代理建立。在HTML中,根元素就是html元素。不过有些浏览器会使用body元素作为根元素。在大多数浏览器中,初始包含块是一个视口大小的矩形。
对于一个非根元素,若其postion值是relative|static,包含块设置为最近的块级框,表单元格或行内块祖先框的内容边界构成。
对于一个非根元素,若其postion值是absolte,包含块设置为最近的定位元素(即position值不为static的祖先元素)。
2)偏移属性
position:static|relative|absolte的定位机制使用了4个属性来描述定位元素各边相对于其包含块的偏移,称之为偏移属性(offset properties)。
top,right,bottom,left
值:<length>|<percentage>|auto|inherit
初始值:auto
应用于:定位元素
百分数:对于top和bottom,相对于包含块的高度,对于right和left,相对于包含块的宽度。
这些属性描述了距离包含块最近边的偏移。
3.宽度和高度
若想为定位元素指定一个特定的宽度(高度),显然要用width(height)属性。但若指明top,right,bottom,left来描述元素4个边的放置位置,则元素的高度和宽度将由这些偏移隐含确定。
4.内容溢出和剪裁
1)溢出
若一个元素固定为某个特定大小,但内容在元素中放不下,此时就可以利用overflow属性来控制。
overflow:visible|hidden|scroll|auto|inherit
初始值:visible
应用于:块级元素和替换元素
继承性:无
默认值visible表明,元素的内容在元素框之外可见。一般地,这会导致内容超出其自己的元素框,但不会改变框的形状。
如果overflow设置为scroll,元素的内容会在元素框的边界处剪裁——即,溢出的部分将无法看到。
如果overflow设置为hidden,元素的内容在元素框的边界处剪裁,不过不会提供滚动接口使用户访问超出剪裁区域的内容。
如果overflow设置为auto,这允许用户代理来确定采用何种行为。
2)内容剪裁(由于兼容性,不推荐使用)
clip:rect(top,right,bottom,left)|auto|inherit
初始值:auto
应用于:绝对定位元素
继承性:无
4.元素可见性
visibility:visible|hidden|collapse|inherit
初始值:visible
应用于:所有元素
继承性:有
使用visibility只需注意visibility:none与display:none之间的区别。
上一篇: 说说标准系列目录
下一篇: HTML5的几点考虑
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
服务商多线程下载流量为什么剧增呢?小弟我朋友公司用万网的空间,流量很奇怪
(转)09年份最实用的小抄/手册总结:HTML, CSS, PHP, Javascript
HTMLParser运用
div+css中定位属性解决办法
js画图开发库-mxgraph-[control-缩放(放大、缩小).html]
怎么让一个DIV永远静止在屏幕某处
现在怎么在你的站点下使用HTML 5(3)
DIV+CSS绝对定位跟相对定位详解
网页中flash wmode属性你会用吗?
推荐阅读
更多>
CSS:诠释格式不当引起背景色无效
上载struts-html.tld
运用表单制造网页的五点技巧
web中使用外部链接CSS文件的形式怎样修改文本框达到如下效果
有没有HTML代码,让网友打开网页的时候静音?解决方案
HTML 色彩图表
html自定义input type='file'式样
CSS文集《The CSS Anthology》 第二章 文本格式化及其它基础知识 (一)
html+jquery透过传递json访问后台控制层
HTML 4.01 / XHTML 1.0标签列表(按效能排列)
IE8 怎么让无序列表中的文字与里面的div在垂直方向都居中
深入透析样式表滤镜(上)
高手求教请教上做一个4行3列的表格不用TABLE怎么用DIV代码写
用css兑现模仿火狐社区的一个提示框
CSS学习3
关于DIV+CSS的一个弱有关问题.
为什么小弟我的代码不能进行跳转呢
innerHTML 异常(转载)
用js兑现的对css的一些操作方法,集合,方便需要用js控制css的朋友
学习网页制造基础入门教程(11)留意的效果