css绝对定位相对定位居中_css定位居中

hacker|
96

文章导读:

利用CSS堆定位元素位置的方式有哪些呢?

css常用的定位方式有五种:

1、static定位(普通流定位) -------------- 默认定位

2、float定位(浮动定位) 例:float:left;

有两个取值:left(左浮动)和right(右浮动)。浮动元素会在没有浮动元素的上方,效果上看是遮挡住了没有浮动的元素,有float样式规则的元素是脱离文档流的,它的父元素的高度并不能有它撑开。

如果父元素的宽度太窄,那么其他浮动元素会向下移动,直到有足够的空间(左图所示);如果浮动元素的高度不同,那么其他浮动元素向下移动时,就有可能会出现卡住的情况(下图所示)

注意:浮动元素的外边缘不会超过父元素的内边缘;浮动元素不会上下浮动;浮动元素不会互相重叠,会像行内块元素一样排列。

如果想要既设置浮动,又使父元素的高度被浮动元素撑开,即清除子元素浮动对父元素带来的高度的影响,有四种方法可以实现:

假设HTML代码部分为:

div class="7d01-008f-d090-7eaf parent" 这是父元素

div style="float:left" 这是子元素/div

/div

1) 为父元素设置固定高度 -------------缺点:不知道具体高度没办法设置

CSS代码部分:

.parent{

//...

height:xxx; //某个固定值

}

2) 在父元素内,在浮动元素的下方多写一行代码:div style="clear:both"/div ------------- 缺点:增加代码冗余

HTML代码部分:

div class="008f-d090-7eaf-3c83 parent" 这是父元素

div style="float:left" 这是子元素/div

div style="clear:both"/div

/div

3) 为父元素设置css规则:overflow:hidden ------------- 缺点:有时候不希望超出部分隐藏

.parent{

// ...

overflow:hidden ; //某个固定值

}

4) 内容生成 ------------- 最优的方法,推荐

CSS代码部分:

.parent:after{

content:'';

display:'block';

clear:both;

}

3、relative定位(相对定位) position:relative;

相对本元素的左上角进行定位,top,left,bottom,right都可以有值。虽然经过定位后,位置可能会移动,但是本元素并没有脱离文档流,还占有原来的页面空间。可以设置z-index。使本元素相对于文档流中的元素,或者脱离文档流但是z-index的值比本元素的值要小的元素更加靠近用户的视线。

相对定位最大的作用是为了实现某个元素相对于本元素的左上角绝对定位,本元素需要设置position为relative。

4、absolute定位(绝对定位) position:absolute;

相对于祖代中有relative(相对定位)并且离本元素层级关系上是最近的元素的左上角进行定位,如果在祖代元素中没有有relative定位的,就默认相对于body进行定位。

5、fixed定位(固定定位)position:fixed

相对于窗口的位置,而且不受其他网页内元素影响,永远处于浏览器窗口的相对位置。

绝对定位是脱离文档流的,与浮动定位是一样的效果,会压在非定位元素的上方。可以设置z-index属性。

注意:当同时有浮动元素和绝对定位元素出现并且浮动元素没有设置z-index,浮动元素是压在绝对定位元素上的,即离用户的视线更近。

CSS绝对定位元素居中的几种方法

css绝对定位,可以用位置来居中。我用一个例子给你说明一下。像通栏的banner,要绝对定位居中的话,可以这样。img相对父级定位,向左偏移50%;再margin-left:-960px(父级宽度的一半)。这是width:100%(1920px)。

.public_banner{ width:100%; min-width: 1200px; height: 500px;overflow: hidden; }

.public_banner img{position:relative; top:0; left:50%; margin-left:-960px; }

不知道这样能不能帮到你,你可以把具体的问题拿出来。

css绝对居中几种方法

水平或者垂直居中单一的要求很好做到,我说几种自己总结的常用的水平且垂直居中的几种方法:

第一种 借助inline-block的特点

#d1{

display:inline-block;

width:500px;

height:500px;

border:1px solid red;

text-align:center;

}

#d1:after{

content:"";

display:inline-block;

height:100%;

vertical-align:middle;

background:#000;

}

#d2{

display:inline-block;

width:200px;

height:200px;

border:1px solid red;

vertical-align:middle;

}

div id="d1"

div id="d2"/div

/div

第二种 利用css的transform 好用但是兼容性不好,IE10+以及其他现代浏览器才支持(手机开发可忽略)

.box{width:300px;height:300px;border:1px solid red;position:relative;}

.content{

position:absolute;

width:100px;

height:100px;

border:1px solid red;

margin:0 auto;

top:50%;left:50%;

/* transform:translateY(-50%); 仅垂直居中*/

/* transform:translateX(-50%); 仅水平居中*/

transform: translate(-50%, -50%);

/*

若父容器下只有一个元素,且父元素设置了高度,则只需要使用相对定位即可

父元素{

height:xxx;

}

.子元素 {

position: relative;

top: 50%;

transform: translateY(-50%);

}

*/

}

div class="d090-7eaf-3c83-b135 box"

div class="7eaf-3c83-b135-234f content"/div

/div

第三种:绝对定位之后的偏移

.box{

border:1px solid red;

width:300px;height:300px;position:relative;

}

.content{

border:1px solid red;

width: 200px; height: 200px;

position: absolute; left: 50%; top: 50%;

margin-top: -100px; /* 高度的一半 */

margin-left: -100px; /* 宽度的一半 */

}

div class="047d-cb63-2838-8dd0 box"

div class="cb63-2838-8dd0-47fd content"/div

/div

第四种:定位之后的margin: auto

.box{

border:1px solid red;

width:300px;height:300px;position:relative;

}

.content{

width: 200px;

height: 200px;

position: absolute;

left: 0;

top: 0;

right: 0;

bottom: 0;

margin: auto;

border:1px solid red;

}

div class="2838-8dd0-47fd-4518 box"

div class="8dd0-47fd-4518-bd1d content"/div

/div

第五种 flex布局

div style="display:flex; display: -webkit-flex; justify-content:center;align-items:center;width: 300px; height: 300px;border:1px solid red;"

div style="width: 200px; height: 200px;border:1px solid red;"/div

/div

第六种利用display:table-cell的vertical-align属性 子元素加上“display:inline-block;”可水平居中

div style="display:table-cell;vertical-align:middle;text-align:center;width:300px;height:300px;border:1px solid red;"

div style="border:1px solid red;width:200px;height:200px;display:inline-block;"/div

/div

第七种 使用css3中的display:-webkit-box的用法这种方法还没有得到浏览器的普遍支持,如有兴趣,自行学习

3条大神的评论

  • avatar
    访客 2022-09-25 下午 07:21:43

    文章导读:1、利用CSS堆定位元素位置的方式有哪些呢?2、CSS绝对定位元素居中的几种方法3、css绝对居中几种方法利用CSS堆定位元素位置的方式有哪些呢?css常用的定位方式有五种:1、static定位(普通流定位) -------------- 默认定位2

  • avatar
    访客 2022-09-25 下午 05:00:57

    动,直到有足够的空间(左图所示);如果浮动元素的高度不同,那么其他浮动元素向下移动时,就有可能会出现卡住的情况(下图所示)注意:浮动元素的外边缘不会超过父元素的内边缘;浮动元素不会上下浮动;浮动元素不会互相重叠,会像行内块元素一样排列。如果想要既设置浮动,又使父元素的高度被浮动

  • avatar
    访客 2022-09-26 上午 01:43:51

    例:float:left;有两个取值:left(左浮动)和right(右浮动)。浮动元素会在没有浮动元素的上方,效果上看是遮挡住了没有浮动的元素,有float样式规则的元素是脱离文档流的,它的父元素的高度并不能有它撑开。如果父元素的宽度太窄,那么其他浮动元素会向下移动,直到有足够的空间

发表评论