• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > 对CSS中的Position、Float属性的一些深入探讨

对CSS中的Position、Float属性的一些深入探讨

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含Position,Float等相关知识,佚名 希望在学习及工作中可以帮助到您

本文主要探讨点:

1.Position、Float属性的基本使用方法
2.Position、Float属性对元素所造成的影响
3.Position、Float属性交叉使用上面的影响
4.Position、Float属性使用上的小技巧

本文结构点:

1.HTML布局的基本要点(点我直接跳转)
  盒子模型
  HTML的普通流

2.Position属性(点我直接跳转)
  属性值介绍
  用法介绍
  一些关于position的小知识

3.Float属性(点我直接跳转)
  属性值介绍
  用法介绍
  与Position之间的兼容问题

HTML布局的基本要点:

如果要掌握、运用好Position、Float属性必须要对HTML的两个基本点有清晰的了解。

1.盒子模型(box model)
2.HTML的普通流(normal flow)
盒子模型
在HTML中元素的盒子模型分为两种:块状元素、行内元素,请注意这里的块状元素(Block)和行内元素(Inline)与Display属性中的inline、block两个属性值并不等同。盒子模型中的Inline、Block类似于是Display属性的父类,例如:Display属性中的list-item属性值是属于块状(Block)类型的。

我们直观的上看两种盒子模型的区别

•块状(Block)类型的元素可以设置width、height属性,而行内(Inline)类型设置无效。
•块状(Block)类型的元素会独占一行(直观的说就是会换行显示,无法与其他元素在同一行内显示,除非你主动修改元素的样式),而行内(Inline)类型的元素则都会在一行内显示。
•块状(Block)类型的元素的width默认为100%,而行内(Inline)类型的元素则是根据自身的内容及子元素来决定宽度。
列举出一些大家常见的元素的分类

•块状元素:P、DIV、UL、LI、DD、DT...
•行内元素:A、IMG、SPAN、STRONG...
HTML的普通流
浏览器在读取HTML源代码的时候是根据元素在代码出现的顺序读取,最终元素的呈现方式是依据元素的盒子模型来决定的。行内元素是从左到右,块状元素是从上到下。(如下图)


如果你不改变元素的默认样式前提下,元素在HTML的普通流中会“占用”一个位置,而“占用”位置的大小、位置则是由元素的盒子模型来决定。因此,在后续讲的Position、Float属性是否会使元素脱离这个普通流是一个关键点。

Position属性:
我们首先来谈谈Position属性,因为Position属性能够很好的体现HTML普通流这个特征。重点在于应用了不同的position值之后是否有脱离普通流和改变Display属性这两点。

Position属性值
Position的属性值共有四个static、relative、absolute、fixed。

Static
所有元素在默认的情况下position属性均为static,而我们在布局上经常会用到的相对定位和绝对定位常用的属性top、bottom、left、right在position为static的情况下无效。其用法为:在改变了元素的position属性后可以将元素重置为static让其回归到页面默认的普通流中。

Relative
俗称的相对定位,重点在于对相对理解。我们此前说过每个元素在页面的普通流中会有“占用”一个位置,这个位置可以理解为默认位置,而相对定位就是将元素偏离元素的默认位置,但普通流中依然保持着原有的默认位置,并没有脱离普通流,只是视觉上发生的偏移。
我们先用块状元素来做个示例:


我们再来看看行内元素(在这里用大家最常用的span来做示例)


请注意看,在这里我是有对span进行width属性的赋值(为100px)。但是我们可以看到span在运用了relative这个position属性值后,依然对width属性无效,换而言之,position: relative并没有改变行内元素的Display属性,这个概念非常重要(注意与接下来的absolute的区别)。

Absolute

俗称的绝对定位,绝对定位是相对而言的,怎么理解呢?应用了position: absolute的元素会循着节点树中的父(祖)元素来确定“根”,然后相对这个“根”元素来偏移。如果在其节点树中所有父(祖)元素都没有设置position属性值为relative或者absolute则该元素最终将对body进行位置偏移。应用了position: absolute的元素会脱离页面中的普通流并改变Display属性(重点)!

我们先用一个默认嵌套的DIV来做示例



现在我们对A-2这个div设置绝对定位(Top: 0, Left: 0),而没有对它的父元素(A、A-1)设置任何的position值


可以看到(A-2)最终是根据body来产生了位移,让我们对比分别设置一下父元素position。

从上面的图,我们可以总结以下几个结论。

1)块状元素在position(relative/static)的情况下width为100%,但是设置了position: absolute之后,会将width变成auto(会受到父元素的宽度影响)。

2)元素设置了position: absolute之后,如果没有设置top、bottom、left、right属性的话,浏览器会默认设置成auto,而auto的值则是该元素的“默认位置”。即设置position: absolute前后的offsetTop和offsetLeft属性值不变。
特殊情况:

Firefox的话会直接将top、left设置成offsetTop和offsetLeft的值而非auto。
IE7下的表现更类似于float,会附加到父元素的

您可能想查找下面的文章:

  • 深入理解css中position属性及z-index属性(推荐)
  • css关于position属性的用法详解(绝对定位和相对定位的混淆)
  • 老生常谈position定位——让人又爱又恨的属性
  • 浅谈CSS中display/float/position属性值的相互影响
  • css(display,float,position)深入理解
  • css position 设置元素的定位方式详解
  • CSS position:absolute全面了解
  • CSS 定位之position全面了解
  • 使用CSS3的ruby-position固定注音位置的用法示例
  • 总结CSS的position定位属性在使用的一些重点

相关文章

  • 2017-08-06css移动端实现与pc端一样的:acitve效果
  • 2017-08-06使用css3实现的windows8开机加载动画
  • 2017-08-06利用CSS3实现单选框动画特效示例代码
  • 2017-08-06url 关于自动换行问题
  • 2017-08-06详解CSS3的box-shadow属性制作边框阴影效果的方法
  • 2017-08-06CSS重置(CSS Reset) 让网页样式在各浏览器中表现一致
  • 2017-08-06CSS中的inherit使用技巧小结
  • 2017-08-06CSS 字体属性font相关的用法
  • 2017-08-06一个挺常用的float布局div问题解决方法
  • 2017-08-06IE6 Bug overflow:hidden失效

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • 使用css3背景渐变中的透明度来设置不同颜色的背景渐变
    • 不用JS只用CSS制作的网页下拉菜单
    • IE下css常见问题总结及解决
    • 背景图片随屏幕大小变化问题的解决方法
    • CSS 样式命名规则
    • CSS之Position全面认识
    • css 不兼容性问题小结
    • css3设置box-pack和box-align让div里面的元素垂直居中
    • 分享CSS3制作卡片式图片的方法
    • IE6/IE7/IE8/Firefox的CSS各种兼容margin问题解决办法

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有