| 加入收藏| 设为首页| 联系我们

首页 站长学习 站长之家 源码下载 建站素材 书籍教程 常用工具
 您现在的位置: 动力中国 >> 网页制作 >> Javascript教程 >> 文章正文  
 通过JAVAScript实现页面自适应
 

通过JAVAScript实现页面自适应

http://www.domcn.org  文章来源:本站收藏  点击数:

  关键字:通过JAVAScript实现页面自适应

        有时候,我们可能需要象新版的Yahoo邮箱一样,让一些数据显示块可以根据页面大小进行自适应。事实并不难,但是如果单纯用CSS控制的话,往往不能完全实现我们要的效果,这时候需要借助Javascript,Javascript可以让我我们实现司空见怪的自适应页面,在iSunXoft的HR开源项目就应用到.
        实现原理:
         获取IE显示屏幕的宽高.确定哪些对象是绝对位置是固定的,那些是不固定的,哪些长宽是固定,然后象WIN FORM程序一样,根所软件界面的大小,进行设计相关对象的长宽,绝对位置等属性,但是在WEB上程序没有办法实时检测到窗口大小变化,只能用让实现自适应的方法通过SetTimeout 函数进行隔时递归调用.
         下面是摘自iSunXoft Hr开源项目SysForm.aspx实现的方法.
         注:$()是有变化的元素.
   var h;
   var w;
   function resize()
   {  
   
    var he = document.body.offsetHeight;
    var wi = document.body.offsetWidth;
    if($(DataTable).style.display.toLowerCase()==||$(DataTable).style.display.toLowerCase()==inline)
    {
     if (h==he&&w==wi)
     {
      if($(leftMenu).style.display.toLowerCase() == none )
      {
       $(DivDataList).style.width = wi - 30;
      }
      else
      {
       $(DivDataList).style.width = wi - 223;
      }       
      setTimeout(resize(),1000);
      return;
     }
     h = he;
     w = wi;
    
     if (he>100)
     {
      $(DivDataList).style.height = he - 172;
     
     }
     if(wi>200)
     {
      $(DivDataList).style.width = wi - 223;
      if($(leftMenu).style.display.toLowerCase() == none )
      {
       $(DivDataList).style.width = wi - 30;
      }
     }
    }

    if($(DataEmpWidows).style.display.toLowerCase()==inline||$(DataEmpWidows).style.display.toLowerCase()==)
    {
     if (h==he&&w==wi)
     {
      if($(leftMenu).style.display.toLowerCase() == none )
      {
       $(DataEmpWidows).style.width = wi - 30;
      }
      else
      {
       $(DataEmpWidows).style.width = wi - 223;
      }       
     }
     h = he;
     w = wi;
     if (he>150)
     {
      $(DataEmpWidows).style.height = he - 132;
     }
     if(wi>200)
     {
      $(DataEmpWidows).style.width = wi - 223;
      if($(leftMenu).style.display.toLowerCase() == none )
      {
       $(DataEmpWidows).style.width = wi - 30;
      }
     }
   
    }
    if(typeof($(EipWindows)) != undefined)
    {
     //if($(EipWindows).style.display.toLowerCase()==inline)
     //{
     // if (h==he&&w==wi)
     // {
     //  if($(leftMenu).style.display.toLowerCase() == none )
     //  {
     //   $(EipWindows).style.width = wi - 30;
     //  }
     //  else
     //  {
     //   $(EipWindows).style.width = wi - 223;
     //  }       
     // }
     // h = he;
     // w = wi;
     // if (he>150)
     // {
     //  $(EipWindows).style.height = he - 132;
     // }
     // if(wi>200)
     // {
     //  $(EipWindows).style.width = wi - 223;
     //  if($(leftMenu).style.display.toLowerCase() == none )
     //  {
     //   $(EipWindows).style.width = wi - 30;
     //  }
     // }   
     //}
    }
    setTimeout(resize(),1000);
   }
   resize();

   然后就在网页上调用resize();一旦窗口大小有变化,或是分辩率有变化,都能确保能够实现真正意义上的自适应.


通过JAVAScript实现页面自适应
  • 上一篇文章:

  • 下一篇文章:
  •  热门文章
    普通文章 电子邮件改头换面 四公司畅谈未
    普通文章 PC病毒史上最声名狼藉的八大病
    普通文章 Rails系统中的AJAX开发技术简析
    普通文章 基于ASP.NET AJAX框架实现表单
    普通文章 开发ASP.NET AJAX客户端定制行
    普通文章 用JFreeChart对JSP报表进行增强
    普通文章 SQL Server 2005上的CLR和ADO.
    普通文章 SQL Server 2005的XML支持机制
    普通文章 Firefox中标签式浏览技巧大全
    普通文章 Tomcat中的Session和Cookie大揭
     
     推荐文章
    推荐文章 把Google地图嵌入网页 就是这么
    推荐文章 迅雷搜索候选资源出错的解决
    推荐文章 轻松去除迅雷里的各种广告和资
    推荐文章 突破限制 免费领养到QQ空间五级
    推荐文章 Rational统一过程RUP贴近中小软
    推荐文章 构建自己的轻量级XML DOM分析程
    推荐文章 WPS Office 2007技巧:妙用配置
    推荐文章 Excel 2007:求余数函数实用进阶
    推荐文章 浅谈ASP.NET的Postback
    推荐文章 软件开发中项目需求管理简述
     
     相关文章
    没有相关文章
    设为首页 | 加入收藏 | 广告合作 | 联系站长 | 版权申明 |
    动力中国为网友提供免费学习资料,可用资源,如果您认为我们的相关内容侵害到了您的权利请联系管理员
    Copyright © 2006-2008 domcn.org All Rights Reserved.