美文网首页
任务10-浮动、定位

任务10-浮动、定位

作者: 小木子2016 | 来源:发表于2016-08-30 11:01 被阅读0次

    1. 文档流的概念指什么?有哪种方式可以让元素脱离文档流?

    文档流是文档中可显示对象在排列时所占用的位置。比如网页的div标签它默认占用的宽度位置是一整行,p标签默认占用宽度也是一整行,因为div标签和p标签是块状对象。 网页中大部分对象默认是占用文档流,也有一些对象是不占文档流的,比如表单中隐藏域。
    浮动和定位可以是元素脱离文档流
    浮动:通过设置float属性
    定位:通过设置position属性来控制。绝对定位:position:absolute/固定定位:position:fixed

    2. 有几种定位方式,分别是如何实现定位的,使用场景如何?

    CSS 定位 (Positioning) 属性允许你对元素进行定位。定位的基本思想很简单,它允许你定义元素框相对于其正常位置应该出现的位置,或者相对于父元素、另一个元素甚至浏览器窗口本身的位置。

    属性 使用场景
    static 默认值。没有定位,元素出现在正常的流中(忽略top,bottom,left,right或者z-index申明) 默认值不设置。
    relative 生成相对定位的元素,相对于其正常位置进行定位。占用空间,相当于原元素的位置移动,不会脱离文档流。如:left:20px会向元素的left位置添加20像素。 其它元素定位时需要把它自身作为参考点。
    absolute 生成绝对定位的元素,相对于static定位以外的第一个父元素进行定位。元素的位置通过left,top,right以及bottom属性进行规定,会脱离文档流。 元素定位时把父元素作为参考点。
    fixed 生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过left,top,right以及bottom属性进行规定。 广告窗口或底部菜单,用于固定位置显示的地方。

    3. absolute, relative, fixed 偏移的参考点分别是什么?

    absolute的参考点是离最近的元素position设置fixed、relative的父级或者祖先元素,如果父元素没有,则一层一层往上找,最终到body元素。
    relative的参考点是其原来自身的位置。
    fixed的参考点是浏览器的窗口。

    4. z-index 有什么作用? 如何使用?

    z-index属性设置元素的堆叠顺序。拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的前面。
    z-index只有在使用了定位属性(即position且值为relative\absolute\fixed)的元素上才可使用;有较高z-index值的元素比z-index值较低的元素离读者更近;z-index的值是正负整数。

    5. position:relative和负margin都可以使元素位置发生偏移?二者有什么区别?

    position:relative使元素偏移时,仅仅只是自身位置发生偏移,并不影响其他元素的布局。


    margin设置负值是元素偏移时,不但改变了元素本身,而且还改变了周围其他元素的布局。

    6. 如何让一个固定宽高的元素在页面上垂直水平居中?

    首先将position值设置为absolute,让元素脱离文档流,然后设置top和left为50%,让元素的左上角位于页面中点,最后通过设置margin为负值使元素在页面上垂直水平居中。

    7. 浮动元素有什么特征?对其他浮动元素、普通元素、文字分别有什么影响?

    特征

    • 浮动会让元素脱离文档流
    • 浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止
    • 浮动元素不会互相重叠
    • 如果没有足够的空间,浮动元素会被挤到新的一行

    影响

    • 其他浮动元素:浮动元素会依次排在其之前浮动元素左边或右边,直到其父元素不能放下,将会被挤到新的一行。
    对其他浮动元素影响
    • 普通元素:浮动元素会浮在页面上,后面的普通元素将会占据其原来的位置
    对普通元素的影响
    • 文字:文字会围绕着浮动元素
    对文字的影响

    8.清除浮动指什么? 如何清除浮动?

    清除浮动是指解除浮动带来的负面影响,比如由于浮动,父元素无法撑起高度,影响与父元素同级的元素;与浮动元素同级的非浮动元素会紧随其后;若非第一个元素浮动,则该元素之前的元素也需要浮动,否则会影响页面显示结构。
    如何清除浮动可以通过clear属性来清除浮动,CSS中的属性是 clear:left | right | both | none;一定要牢记:这个规则只能影响使用清除的元素本身,不能影响其他元素。

    未清除浮动之前 清除浮动之后

    相关文章

      网友评论

          本文标题:任务10-浮动、定位

          本文链接:https://www.haomeiwen.com/subject/bxswsttx.html