HTML5技术

DOCTYPE对$(window).height()取值的影响 - hnscdg

字号+ 作者:H5之家 来源:博客园 2016-07-21 14:00 我要评论( )

前言:公司项目需要用到一个弹框垂直居中,网上类似的垂直居中弹出层大同小异,因为项目是基于Jquery 下的,所以用$(window).height()-layer.height())/2 +$(document).scrollTop()取得垂直的位移。测了各种浏览器没问题,后台人员移值到项目中后,出问题了,

前言:公司项目需要用到一个弹框垂直居中,网上类似的垂直居中弹出层大同小异,因为项目是基于Jquery 下的,所以用$(window).height()-layer.height())/2 +$(document).scrollTop()取得垂直的位移。测了各种浏览器没问题,后台人员移值到项目中后,出问题了,当页面超出一屏时,在 chrome和FF下,弹出框不是在当前屏的垂直居中,而是相对于整个网页的居中。

查阅各方资料,所有结论都指出:
1.窗口高度,$(window).height()
2.文档高度,$(document).height()
3.被卷起的高度,$(window).scrollTop()

找到原因:而后,发现后台人员的页面没有设DOCTYPE,所以在chrome中,$(window).height()=$(document).height(),$(document).height()表示在网页实际内容高度没有满一屏时表示整个窗口的高度(窗口放大缩小时这个值会变化),页当超过一屏时表示为整个网页内容的实际高度,这点没有异议,跟设不设DOCTYPE没有影响。但是:$(window).height()在DOCTYPE为transitional.dtd时无论网页内容实际高度超不超出满屏情况下,都等于是整个窗口的高度(窗口放大缩小时这个值会变化),如果没有设DOCTYPE则$(window).height()=$(document).height(),在即当内容超一屏时$(window).height()为网页实际高度,并不是所说的等于窗口高度。

解决办法:s要取得窗口的高度,只能根据DOCTYPE来做相应的更改,在没有设DOCTYPE时做如下处理
   if($(document).height()>=$(window).height()){
    _windowHeight=document.body.clientHeight;
   }else{//alert($(window).height());
    _windowHeight=$(document).height();
   };
在有设DOCTYPE为transitional.dtd时,windowHeight=$(window).height()

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • Doctype的作用?标准(严格)模式,怪异(混杂)模式的区别,它们的意义? - 打怪的码农队长

    Doctype的作用?标准(严格)模式,怪异(混杂)模式的区别,它们的

    2017-04-29 09:03

  • 从USB驱动器运行Windows 10 - SmallProgram

    从USB驱动器运行Windows 10 - SmallProgram

    2017-03-11 09:01

  • HTML 元素和有效 DOCTYPES - 大西瓜2号

    HTML 元素和有效 DOCTYPES - 大西瓜2号

    2017-03-09 16:00

  • js图片前端预览之 filereader 和 window.URL.createObjectURL - 冒雨ing

    js图片前端预览之 filereader 和 window.URL.createObjectURL - 冒雨

    2016-06-30 13:00

网友点评
$