跨浏览器确定浏览器窗口位置及窗口大小

本文介绍了如何在不同浏览器中获取窗口的位置(screenLeft, screenTop, screenX, screenY)和大小(innerWidth, innerHeight, outerWidth, outerHeight)。针对IE8及更早版本的兼容性问题,提供了相应的解决方案,以获取页面可视区的宽度和高度。" 122045106,11666153,大学计算机等级考试解析,"['计算机基础', '编程语言', '网络协议', '物联网', '教育']
摘要由CSDN通过智能技术生成
确定窗口位置一共分两类,首先是 window.screenLeft 和 window.screenTop,其次是window.screenX 和 window.screen.Y.

区别:window.screenLeft 和 window.screenTop 是 IE Safari Opera Chrome 中的方法。

            window.screenX 和 window.screen.Y 是 Firefox,同时Safari Opera Chrome也支持该属性,只是Opera中获得的数值与window.screenLeft 和 window.screenTop不一致。

兼容性写法

           var scrernLeft = window.screenLeft?window.screenLeft:window.screenX;
           var screenTop = window.screenTop?window.screenTop:window.screenY;

确定窗口大小:

        IE9+ Safari Opera Chrome Firefox 为我们提供了四种属性 innerWidth、innerHeight、outerWidth、outerHeight。

        innerWidth  innerHeight视图区的宽高,outerWidth、outerHeight整个浏览器的宽高包括工具栏顶部。

        IE8及更早的版本中没有提供可以取得当前浏览器窗口尺寸的属性,但通过DOM提供了页面可视区的相关信息。

        IE Safari Opera Chrome Firefox  document.documentElement.clientHeightdocument.documentElement.clientWidth保存着浏览是视图区大小(即可视区)

        IE6中这些属性必须在标准模式才能取得相同信息,如果是混杂模式,必须通过document.body.clientWidth、document.body.clientWidth来获取。而对于混杂模式下的Chrome ,两种方法都可以。

所以在考虑兼容性问题上,根本没有办法确定浏览器窗口本身的大小,但可以获得页面可视区大小:兼容性写法:

var pageWidth = window.innerWidth;
var pageHeight = window.innerHeight;
if( typeof pageWidth !="number") {
    if(document.compatMode == "CSSlCompat") {
        pageWidth = document.documentElement.clientWidth;
        pageHeight = document.documentElement.clientHeight;
    }
    else {
        pageWidth = document.body.clientWidth;
        pageHeight = document.body.clientHeight;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值