利用onresize使得div可以随着屏幕大小而自适应的代码

  当我们让div居中时候,一般有两种方法,一种是固定左右宽度,也就是使用像素绝对定位;另一种是用百分比来相对定位,在这种两种方式下,绝对定位是不能让div随着屏幕而自适应的,而用百分比就可以,但是,是用百分比就会有一个新的问题,如果我们的页面中有这么一句

  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

  的时候,top的百分比将会失效,而删除这句话的时候,一切正常,都是不知道这句标准的声明为什么会带来如此的不便

  针对这个问题,我使用的下面的方法来实现div的自适应

  首先 我用的是绝对定位的方式,先设置好div的左右上下边距。在body中添加两个事件,

  <body bgcolor="#666666" onresize="test()" onload="getwah()">

  getwah()用来获取屏幕的大小和div的各个边距,并计算出它们的差

  

复制代码 代码如下:

  var height,width,width_cha1,width_cha2;

  function getwah()

  {

  if(document.documentElement && document.documentElement.clientWidth)

  {d_width = document.documentElement.clientWidth;}

  else if(document.body)

  {d_width = document.body.clientWidth;}

  width=parseInt(d_width);

  width_cha1=width-parseInt(document.getElementById("backi").style.left)

  width_cha2=width-parseInt(document.getElementById("massage_box").style.left)

  }

  当屏幕大小变化的时候(onresize)触发test()函数,该函数就是用户根据之前获得屏幕与边距的差值重新设置div的边距,这样就可以实现党屏幕的大小改变后,div的边距也会相应地改变,从而实现div可以随着屏幕大小的改变而自适应

  

复制代码 代码如下:

  function test()

  {

  if(document.documentElement && document.documentElement.clientWidth)

  {d_width = document.documentElement.clientWidth;}

  else if(document.body)

  {d_width = document.body.clientWidth;}

  var now_left1=parseInt(d_width )-width_cha1;

  var now_left2=parseInt(d_width )-width_cha2;

  document.getElementById("backi").style.left=now_left1

  document.getElementById("massage_box").style.left=now_left2

  }