13618602336  027-68772750

网站建设知识分享静态页面布局之Css的position属性

2022-7-21 22:20:11    浏览 857

      CSS的positon属性你了解多少?positon单从英文单词字面意思上讲它表示“位置”的意思。今天武汉珞珈的小编跟大家好好的图解说明一下CSS的positon的使用。CSS的“position”的属性包括以下几种:static、relative、absolute、float”。具体使用请看下面图解说明。




初步效果:



为了后面能更好的了解相关知识点,我特将此例的DOM草图画出来:


上面的DOM图,我想大家一定非常容易的理解,下面就一起来主要看position的使用。

第一步:position: static

在CSS中所有元素的“position”属性的默认值都是“static”,因为不需要显式的为每个元素设置“position:static”。此时大家会问,那这个属性值是不是没有任何意义呢?其实不是的,他在CSS中也会起着很大的作用。我们来看一个实例:

比如说你的两个页面,同时存在“div#div-1”,那么此时你在A面中需要对“div#div-1”进行绝对定位;而在B页面中“div#div-1”又不需要进行绝对定位。

A页面中“div#div-1”绝对定位:

#div-1 {
                position: absolute;
            }

此时在B页面中不想在进行绝对定位,那么我们就必须在你的样式中显式的重新设置“#div-1”的postion属性为“static”

body.B #div-1 {
                position: static;
            }

第二步:相对定位position:relative

relative称为相对定位,如果你给某个元素指定了postion的值为“relative”,那么你就可以通过“T-R-B-L”(也就是top,right,bottom,left)来设置元素的定位值。

使用relative时有几点需要注意:

  1. 元素设置了relative时,是相对于元素本身位置进行定位;
  2. 元素设置了relative后,可以通过“T-R-B-L”改变元素当前所在的位置,但元素移位后,同样点有当初的物理空间位;
  3. 元素设置了relative后,如果没有进行任何的“T-R-B-L”设置,元素不会进行任何位置改变。

上面三点第一点和第三点来说都是比较好理解,那么现在针对第二点,我们来看一个实例的操作:

在上面的基础上,我们对“div-1”进行向下移动20px;向左移动40px#div-1 {
                    position:relative;
                    top:20px;
                    left:-40px;
                }

我们来看看效果:


从效果图可以再次印证上面说的第二点。元素“div-1”向下移动了20px,向左移动了40px,本身位置变化了,而元素最初所占的物理空间依然还是存在,另外一点元素相对定位后并没有影响其他相邻的元素。

第三步:绝对定位position:absolute


absolute是position中的第三个属性值,如果你给元素指定了absolute,整个元素就会漂出文档流,而且元素自身的物理空间也同时消失了。不像“relative”还具有原先的物理空间。

我们来看一个实例,在div-1a元素上进行绝对定位:
#div-1a {
                position:absolute;
                top:0;
                right:0;
                width:200px;
            }




此时元素“div-1a”不在当初的文档流中,而且其此时定位也是相对于html来进行定位,那么我们有时候并不是需要这样的效果,哪果我们元素div-1a还想在div-1是进行绝对定位,那要怎么办呢?此时就要发挥前面第二步的“relative”作用了。

第四步:relative和absolute的结合

第二步中大家知道元素相对定位“relative”是相对于元素自身定位,而在第三步中大家知道元素绝对定位“absolute”是相对于html。但这种说法只有满足这样的条件才是正常的:“绝对定位元素的任何祖先元素没有进行任何的“relative”或者“absolute”设置,那么绝对定位的元素的参考物就是html”,这样一来,“relative”和“absolute”的结合就能起到很大的作用。

我们接下来看一个截图:


上图做为一个实例来说明“relative”和“absolute”的关系,首先上图中共有三个div放在body内,而且他们三个div的关系是“div-1>div-2>div-3”,而且在div-3有这么一个绝对定位:

下面分几个情况来说明上图的意思:

1、div-1与div-2都没有设置“position:relative”,此时我们的div-3绝对定位后就漂到了上图中“div-3c”的位置上;

2、现在我们在div-2元素中加设置一个“position: relative”,此时我们的div-3绝对定位后就漂到了上图中的“div-3a”的位置;

3、接下来把相对定位的设置换到div-1元素上,此时div-3绝对定位后就到了div-3b的位置。

花这么多心思,我只想说明一点:如果一个元素绝对定位后,其参照物是以离自身最近元素是否设置了相对定位,如果有设置将以离自己最近元素定位,如果没有将往其祖先元素寻找相对定位元素,一直找到html为止。这句话说起起来好像有点拗口,不知道大家能否明白我说的是什么?如果不明白大家可以参考上图或者下面这个实例效果:

回到上面的实例中,如果我们在“div-1”加一个“relative”:

#div-1 {
             position:relative;
            }
            #div-1a {
             position:absolute;
             top:0;
             right:0;
             width:200px;
            }
现在我们相对点不在是第三步中的body了,而是“div-1”了,大家看看与第三步的变化:


 第五步:relative和absolute实现布局效果

这一步只要想演示一下使用相对定位和绝对定位实现的两例布局。在前面的基础上,div-1进行相对定位,而div-1a和div-1b进行绝对定位,从而实现两列布局的效果:

#div-1 {
             position:relative;
            }
            #div-1a {
             position:absolute;
             top:0;
             right:0;
             width:200px;
            }
            #div-1b {
             position:absolute;
             top:0;
             left:0;
             width:200px;
            }
 
以上内容是武汉珞珈网络收集整理,我们公司主要从事网站建设业务,网站推广,网站优化,在武汉网站建设公司是佼佼者。欢迎您的来电。咨询热线:027-68770750


联系我们

CONTACT US

袁经理: 电  话: 地址:武汉市洪山区武珞路珞珈山大厦A座1701室 鄂ICP备09016823号-7

武汉网站建设

我们是专业的。公司有专业的设计师及程序开发人员。主要优势是:

武汉做网站

武汉网站设计

等其他相关业务,欢迎您来电咨询。