目录
引子:
position属性的几个值的概念:
1.相对定位
2.绝对定位
3.z-index属性
常见定位拓展:
1.水平居中
2.水平垂直居中
首页 web前端 html教程 CSS定位问题(3):相对定位,绝对定位_html/css_WEB-ITnose

CSS定位问题(3):相对定位,绝对定位_html/css_WEB-ITnose

Jun 24, 2016 am 11:19 AM

引子:

开始的时候我想先要解决一个问题,怎么设置一个div盒子撑满整个屏幕?

看下面的html代码:

<body>    <div id="father-body">        <div class="item1"></div>    </div></body>
登录后复制

实现方法一:

html, body,#father-body{            height:100%;            width:100%;            background-color:#123456;        }
登录后复制

这里主要解释下%(百分号)在CSS中使用的问题。% 主要是在父级元素或者是祖先元素定义了固定的width 和height 的时候才可以使用(或者说使用的时候才会有效果)。

实现方法二:

#father-body{            position:fixed;            width:100%;            height:100%;            background-color:#123456;        }
登录后复制

这里为#father-body 设置position属性,触发自身的BFC。当对自身使用width 和 height的时候才可以生效。

position的fixed值的含义:

对象脱离常规流,使用 top,right,bottom,left等属性以窗口为参考点进行定位,当出现滚动条时,对象不会随着滚动。

position属性的几个值的概念:

1.相对定位

有了以上的定义,来看一段代码:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>Document</title>    <style type="text/css">    .item1, .item2, .item3{        width:300px;        height:100px;        background-color:#123456;        margin:20px;    }        .item2{            position:relative;            /*top:40px;            left:40px;*/            margin:40px 0 0 40px;        }    </style></head><body>    <div>        <div class="item1"></div>        <div class="item2"></div>        <div class="item3"></div>    </div></body></html>
登录后复制

效果如下图:

当我们使用top right bottom left 这样的属性的时候,CSS代码如下:

<style type="text/css">    .item1, .item2, .item3{        width:300px;        height:100px;        background-color:#123456;        margin:20px;    }        .item2{            position:relative;            top:40px;            left:40px;            /*margin:40px 0 0 40px;*/        }    </style>
登录后复制

可以看到的效果图如下图:

到这里可以验证当使用top right bottom left (这四个属性可以设置具体的像素数也可以设置百分比)这样属性改变元素的位置的时候,不会影响其他元素的位置。而使用margin 这样的属性改变元素的位置会影响其他元素的位置。

示意图如下(图片来自W3CSchool):


2.绝对定位

看下面的一段代码:

<!DOCTYPE html><html lang="en"><head>    <meta charset="UTF-8">    <title>Document</title>    <style type="text/css">        body{margin:20px;}        #body-div{            padding:15px;            background-color:#a0c8ff;            border:1px solid #000000;        }        #body-div div{            padding:10px;            background-color:#fff0ac;            border:1px solid #000000;        }    </style></head><body>    <div id="body-div">        <div class="item1">Box-1</div>        <div class="item2">Box-2</div>        <div class="item3">Box-3</div>    </div></body></html>
登录后复制

效果图如下:

我们为Box-2设置绝对定位属性

.item2{            position:absolute;        }
登录后复制

此时Box-2脱离文档流,效果如下:

这个时候Box-3的位置会占据之前Box-2的位置。且Box-2和Box-3的左边框会重合。且盒子的宽度会根据盒子内部的元素自适应。

当盒子设置了绝对定位但是没有使用top right bottom left设置盒子的偏移量的时候,它仍会占据原先的位置。

那么当设置top right bottom left这些属性的时候会是什么效果呢?

设置下面的代码:

.item2{            position:absolute;            top:0;            right:0;        }
登录后复制

效果如下图:

那么当我们把直接父级元素设置为已定位的元素会怎么样呢?

由上可以得出两个结论:

1.使用绝对定位的盒子以它的“最近”的一个“已经定位”的“祖先元素”为基准进行偏移(定位)。如果没有已经定位的祖先元素,那么就会以浏览器窗口为基准进行定位。2.决对定位的框从标准流中脱离,这意味着它们对其后的兄弟盒子的定位没有影响。其它的盒子好像就当这个盒子(绝对定位的盒子)不存在一样。

3.z-index属性

z-index属性用于调整定位时重叠块的上下位置,与它的名称一样,如果页面为x-y轴,则垂直于页面的方向为z轴。z-index大的页面位于其值小的的上面。

看下面的代码:

.item1{            position:relative;            z-index:3;        }        .item2{            position:absolute;            top:0;            right:0;            z-index:1;        }
登录后复制

常见定位拓展:

以下的代码我都亲测过,均可以达到效果,就不在展示效果图(如果对代码有疑问可以留言):

1.水平居中

1.1行内元素的水平居中

/*行内元素水平居中*/        #body-div{            text-align:center;        }
登录后复制

1.2块级元素的水平居中

/*块级元素水平居中*/        #body-div{            margin:0 auto;        }
登录后复制

1.3多个块级元素水平居中

/*多个块级元素水平居中*/        #body-div{            text-align:center;        }        ##body-div-container{            display:inline-block;        }
登录后复制

2.水平垂直居中

2.1已知宽度高度的垂直水平居中

/*已知高度和宽度的水平垂直居中*/        #body-div{            position:relative;        }        #body-div-container{            width:100px;            height:100px;            position:absolute;            top:50%;            left:50%;            margin:-50px 0 0 -50px;        }
登录后复制

2.2未知宽度高度的垂直水平居中

/*未知高度和宽度的水平垂直居中*/        #body-div{            position:relative;        }        ##body-div-container{            position:absolute;            margin:auto;            top:0;            right:0;            bottom:0;            left:0;        }
登录后复制

2.3当被居中的元素是inline或者是inline-block

#body-div{            display:table-cell;            text-align:center;            vertical-align:middle;        }        ##body-div-container{        }
登录后复制

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
1 个月前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

粘性定位脱离文档流吗 粘性定位脱离文档流吗 Feb 20, 2024 pm 05:24 PM

粘性定位脱离文档流吗,需要具体代码示例在Web开发中,布局是一个很重要的话题。其中,定位是一种常用的布局技术之一。在CSS中,有三种常见的定位方式:静态定位、相对定位和绝对定位。除了这三种定位方式,还有一种比较特殊的定位方式,即粘性定位。那么,粘性定位是否脱离文档流呢?下面我们就来具体探讨一下,并提供一些代码示例来帮助理解。首先,我们需要了解一下什么是文档流

css怎么把图片放中间 css怎么把图片放中间 Apr 25, 2024 am 11:51 AM

CSS 中使图片居中有三种主要方法:使用 display: block; 和 margin: 0 auto;。使用弹性盒子布局或网格布局,设置 align-items 或 justify-content 为 center。使用绝对定位,设置 top、left 为 50%,并应用 transform: translate(-50%, -50%);。

css中元素的定位方法 css中元素的定位方法 Apr 26, 2024 am 10:24 AM

CSS 元素定位有四种方法:静态、相对、绝对和固定定位。静态定位是默认值,元素不受定位规则影响。相对定位相对于元素本身移动元素,不会影响文档流。绝对定位将元素从文档流中移除并相对于其祖先元素定位。固定定位将元素相对于视口定位,始终保持在屏幕上的同一位置。

CSS中bottom属性语法 CSS中bottom属性语法 Feb 21, 2024 pm 03:30 PM

CSS中bottom属性语法及代码示例在CSS中,bottom属性用于指定一个元素与容器底部之间的距离。它可以控制一个元素相对于其父元素底部的位置。bottom属性的语法如下:element{bottom:value;}其中,element表示要应用该样式的元素,value表示要设置的bottom值。value可以是一个具体的长度值,比如像素

什么是layout布局? 什么是layout布局? Feb 24, 2024 pm 03:03 PM

layout布局是指在网页设计中,为了使网页元素按照一定的规则和结构进行排列和展示而采取的一种排版方式。通过合理的布局,可以使网页更加美观、整齐,并且达到良好的用户体验。在前端开发中,有许多种布局方式可以选择,比如传统的table布局、浮动布局、定位布局等。但是,随着HTML5和CSS3的推广,现代的响应式布局技术,如Flexbox布局和Grid布局,成为了

html5怎么让盒子居中 html5怎么让盒子居中 Apr 05, 2024 pm 12:27 PM

在 HTML5 中使盒子居中,有以下方法:水平居中:text-align: centermargin: autodisplay: flex; justify-content: center;垂直居中:vertical-align: middletransform: translate(-50%, -50%);position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);

html怎么对齐文本框 html怎么对齐文本框 Mar 27, 2024 pm 04:33 PM

html对齐文本框的方法:1、文本对齐;2、使用Flexbox布局对齐;3、使用Grid布局对齐;4、使用margin或position进行微调。

bootstrap怎么调整组件的位置 bootstrap怎么调整组件的位置 Apr 05, 2024 am 03:00 AM

Bootstrap提供了多种方式调整组件位置:偏移类:水平偏移组件。辅助类:调整组件对齐方式。栅格系统:控制组件在栅格中占据的列数。行内元素:创建浮动布局。绝对定位:将组件从其常规流中移出并定位在页面上的任何位置。

See all articles