区别: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.clientHeight、document.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;
}
}