您好, 访客   登录/注册

详解网页设计中的定位应用

来源:用户上传      作者:

  定位一直是WEB标准应用中的难点,如果理不清楚定位那么可能应实现的效果实现不了,实现了的效果可能会走样。如果理清了定位的原理,那定位会让网页实现得更加完美。
  
  定位的定义
  在CSS中关于定位的内容是:position:relative | absolute | static | fixed
  static:没有特别的设定,遵循基本的定位规定,不能通过z-index进行层次分级。
  relative:不脱离文档流,参考自身静态位置通过top,bottom,left,right定位,并且可以通过z-index进行层次分级。
  absolute:脱离文档流,通过top,bottom,left,right定位。选取其最近的负极定位元素,当负极position为static时,absoIute元素将以body坐标原点进行定位,可以通过z-in-dex进行层次分级。
  fixed:固定定位,这里它所固定的对象是可视窗口而并非是body或是负极元素。可通过z-index进行层次分级。
  CSS中定位的层叠分级:z-index:auto | number
  auto:遵从其父对象的定位。
  number:无单位的整数值,可为负数。
  
  定位的原理
  可以位移的元素(相对定位)
  在文本流中,任何一个元素都被文本流所限制了自身的位置,但是通过CSS我们依然使得这些元素可以改变自己的位置,我们可以通过float来让元素浮动,我们也可以通过margin来让元素产生位置移动。但是事实上那并非是真实的位移,因为,那只是通过加大margin值来实现的障眼法。而真正意义上的位移是通过top,right,bottom,left(下称TRBL,TRBL可以拆分使用。)针对一个相对定位的元素所产生的。
  是一个宽度为200px,高度为50px,margin:25px;border:25px solid#333;padding:25px;相对定位的元素,并且位移距上50px,距左50px。而下方是一块默认定位的黑色区块。我们看到这个处在文本流的区块被上面的相对定位挡住了一部分,这说明:“当元素被设置相对定位或是绝对定位后,将自动产生层叠,他们的层叠级别自然的高于文本流”。除非设置其z-index值为负值,但是在Firefox等浏览器中z-index为负值时将不会显示。并且我们发现当相对定位元素进行位移后,表现内容已经脱离了文本流,只是在文本流中还为原来的相对定位留下了原有的总宽与总高。这说明在相对定位中,虽然表现区脱离了原来的文本流,但是在文本流中还有此相对定位的原始位置。这点要特别注意,因为在实际应用中如果相对定位的位移数值过大,那么原有的区域就会形成一块空白。
  并且我们注意,定位元素的坐标点是在margin值的左上边缘B点,那么所有的位移的计算将以这个点为基础进行元素的推动。当TRBL为正值时位移的方向是内聚的,由些可推,当TRBL为负值时位移的方向是外放的。在图片中有位移的箭头指向标识,带有加号的是正值位移方向,带有减号的是负值位移方向。
  可以在任意一个位置的元素(绝对定位)
  如上所述,相对定位只可以在文本流中进行位置的上下左右的移动,同样存在一定的局限性。虽然它的表现区脱离了文本流,但是在文本流却依然为其保留了一席之地。这就好比一个打工的人到了外地,但是在老家依然有一个专属于他的位置,这个位置不随他的移动而改变。但是这样很明显就会空出一块空白来,如果希望文本流抛弃这个部分就需要用到绝对定位。绝对定位不光脱离了文本流。而且在文本流中也不会给这个绝对定位元素留下专属空位。这就好比是一个工厂里的工人,如果有一个工人走了自然会要有别的工人来填充这个位置。而移动出去的部分自然也就成为了自由体。绝对定位将可以通过TRBL来设置元素处在任何一个位置。在负极position属性为默认值时,TRBL的坐标原点以body的坐标原点为起始。
  文本流中的内容会顶替绝对定位元素的位置,一点都不会客气。而绝对定位元素自然的层叠于文本流之上。而在单一的绝对定位中,定位元素将会跑到网页的左上角,因为那里是它们的被绝对定位后的坐标原点。
  
  被关联的绝对定位
  上面说的是单一的绝对定位,而在实际的应用中我们常常会需要用到一种特别的形式。即希望定位元素要有绝对定位的特性,但是又希望绝对定位的坐标原点可以固定在网页中的某一个点,当这个点被移动时绝对定位元素希望能保证相对于这个原坐标的相对位置。也就是说需要这个绝对定位要跟着网页移动,并且是固定在网页的某一个固定位置。通常当网页是居中形式的时候,这种效果就会显得特别的重要。要实现这种效果,基本方式就是为这个绝对定位的父级设置为相对定位。那么绝对定位的坐标就会以父级为坐标起始点。
转载注明来源:https://www.xzbu.com/8/view-8736517.htm