网页可见区域宽: document.body.clientWidth;
网页可见区域高: document.body.clientHeight;
网页可见区域宽: document.body.offsetWidth    (包括边线的宽);
网页可见区域高: document.body.offsetHeight   (包括边线的宽);
网页正文全文宽: document.body.scrollWidth;
网页正文全文高: document.body.scrollHeight;
网页被卷去的高: document.body.scrollTop;
网页被卷去的左: document.body.scrollLeft;
网页正文部分上: window.screenTop;
网页正文部分左: window.screenLeft;
屏幕分辨率的高: window.screen.height;
屏幕分辨率的宽: window.screen.width;
屏幕可用工作区高度: window.screen.availHeight;
屏幕可用工作区宽度:window.screen.availWidth;

scrollHeight: 获取对象的滚动高度。  
scrollLeft:设置或获取位于对象左边界和窗口中目前可见内容的最左端之间的距离
scrollTop:设置或获取位于对象最顶端和窗口中可见内容的最顶端之间的距离
scrollWidth:获取对象的滚动宽度
offsetHeight:获取对象相对于版面或由父坐标 offsetParent 属性指定的父坐标的高度
offsetLeft:获取对象相对于版面或由 offsetParent 属性指定的父坐标的计算左侧位置
offsetTop:获取对象相对于版面或由 offsetTop 属性指定的父坐标的计算顶端位置  
event.clientX 相对文档的水平座标
event.clientY 相对文档的垂直座标

event.offsetX 相对容器的水平坐标
event.offsetY 相对容器的垂直坐标  
document.documentElement.scrollTop 垂直方向滚动的值
event.clientX+document.documentElement.scrollTop 相对文档的水平座标+垂直方向滚动的量
Post by molong on 2009-05-19 11:57 PM   #1

要获取当前页面的滚动条纵坐标位置,用:
document.documentElement.scrollTop;
而不是:
document.body.scrollTop;
documentElement 对应的是 html 标签,而 body 对应的是 body 标签。

在标准w3c下,document.body.scrollTop恒为0,需要用document.documentElement.scrollTop来代替;
如果你想定位鼠标相对于页面的绝对位置时,你会发现google里面1000篇文章里面有999.99篇会让你使用 event.clientX+document.body.scrollLeft,event.clientY+document.body.scrollTop, 如果你发现你的鼠标定位偏离了你的想象,请不要奇怪,这是再正常不过的事情。
ie5.5之后已经不支持document.body.scrollX对象了。
所以在编程的时候,请加上这样的判断
if (document.body && document.body.scrollTop && document.body.scrollLeft)
{
top=document.body.scrollTop;
left=document.body.scrollleft;    
}
if (document.documentElement && document.documentElement.scrollTop && document.documentElement.scrollLeft)
{
top=document.documentElement.scrollTop;
left=document.documentElement.scrollLeft;
}

Javascript中的常见问题

下面简单使用Jquery来操作iframe的一些记录,这个使用纯JS与可以实现。

第一、在iframe中查找父页面元素的方法:
$('#id', window.parent.document)

第二、在父页面中获取iframe中的元素方法:
$(this).contents().find("#suggestBox")

第三、在iframe中调用父页面中定义的方法和变量:
parent.method
parent.value

1. 集合类对象问题 
现有代码中许多集合类对象取用时使用 (),IE 能接受,Firefox 不能。 
解决方法:改用 [] 作为下标运算。如:document.forms("formName") 改为

  1. document.forms["formName"];
  2. //又如:
  3. document.getElementsByName("inputName")(1);
  4. //改为
  5. document.getElementsByName("inputName")[1];

2. DIV对象 
在 IE 中,DIV对象可以使用ID作为对象变量名直接使用。在 Firefox 中不能。 
DivId.style.display = "none"; 
解决方法:document.getElementById("DivId").style.display = "none"; 
ps:得对象的方法不管是不是DIV对象,都应该使用getElementById方法。

3. 关于frame 
现有问题:在 IE中 可以用window.testFrame取得该frame,mf中不行 
解决方法:在frame的使用方面Firefox和IE的最主要的区别是: 
如果在frame标签中书写了以下属性: 
那么IE可以通过id或者name访问这个frame对应的window对象 
而mf只可以通过name来访问这个frame对应的window对象 
例如如果上述frame标签写在最上层的window里面的htm里面,那么可以这样访问 
IE: window.top.frameId或者window.top.frameName来访问这个window对象 
Firefox:只能这样window.top.frameName来访问这个window对象 
另外,在mf和ie中都可以使用window.top.document.getElementById("frameId")来访问frame标签 
并且可以通过window.top.document.getElementById("testFrame").src = 'xx.htm'来切换frame的内容 
也都可以通过window.top.frameName.location = 'xx.htm'来切换frame的内容

4. 窗口 
现有问题:IE中可以通过showModalDialog和showModelessDialog打开模态和非模态窗口,但是Firefox不支持。 
解决办法:直接使用window.open(pageURL,name,parameters)方式打开新窗口。 
如果需要传递参数,可以使用frame或者iframe。

5. 在JS中定义各种对象变量名时,尽量使用id,避免使用name. 
在 IE 中,HTML 对象的 ID 可以作为 document 的下属对象变量名直接使用。在 Firefox 中不能,所以在平常使用时请尽量使用id,避免只使用name,而不使用id。

6. document.all 
Firefox可以兼容document.all, 但会生成一条警告。可以用getElementById("*") 或者 getElementByTagName("*)来代替
不过对于document.all.length等属性,则完全不兼容。大家尽量不要使用document.all属性.

7. parentElement 
IE中支持使用parentElement和parentNode获取父节点. 
而Firefox只可以使用parentNode.

8. event 
W3C不支持windows.event 
比方说,在IE里面:

  1. function onMenuClick(){
  2. collapseMenu(event.srcElement);
  3. }

工作正常。不过在Firefox中,则改成:

  1. function onMenuClick(evt){
  2. if(evt == null)
  3. evt = window.event; // For IE
  4. var srcElement = evt.srcElement? evt.srcElement : evt.target;
  5. // IE使用srcElement, 而Firefox使用target
  6. collapseMenu(srcElement);

9. event.x 与 event.y 问题 
在IE 中,event 对象有 x, y 属性,Firefox中没有。 
解决方法: 
在Firefox中,与event.x 等效的是 event.pageX。但event.pageX IE中没有。 
故采用 event.clientX 代替 event.x。在IE 中也有这个变量。 
event.clientX 与 event.pageX 有微妙的差别(当整个页面有滚动条的时候), 
不过大多数时候是等效的。 
如果要完全一样,可以稍麻烦些:

  1. mX = event.x ? event.x : event.pageX;

然后用 mX 代替 event.x

10. 用idName字符串取得对象的问题 
在IE中,利用 eval(idName) 可以取得 id 为 idName 的 HTML 对象,在Firefox中不能。 
解决办法:用 getElementById(idName) 代替 eval(idName).

14. nodeName 和 tagName 问题 
在Firefox中,所有节点均有 nodeName 值,但 textNode 没有 tagName 值。 
在IE中nodeName 的使用有时会有问题。 
解决方法: 
使用 tagName,但应检测其是否为空。

15. input的type属性 
IE下 input.type属性为只读,但是Firefox下可以修改.

16. 自定义属性 
在mf中,自己定义的属性必须getAttribute()取得 
而IE可以直接通过"."运算符获取.

17.const 问题 
在 IE 中不能使用 const 关键字。如 
const constVar = 32; 
在IE中这是语法错误. 
解决方法: 
不使用 const ,以 var 代替.

18. body 对象 
Firefox的body在body标签没有被浏览器完全读入之前就存在,而IE则必须在body完全被读入之后才存在.

19. img对象alt和title的解析 
alt:当照片不存在或者load错误时的提示, 
title:照片的tip说明, 
在IE中如果没有定义title,alt也可以作为img的tip使用,但是在Firefox中,两者完全按照标准中的定义使用 
在定义img对象时,最好将alt和title对象都写全,保证在各种浏览器中都能正常使用

20.childNodes获取的节点 
childNodes的下标的含义在IE和Firefox中不同,Firefox使用DOM规范,childNodes中会插入空白文本节点。 
获取子节点时,一般可以通过node.getElementsByTagName()来回避这个问题。

21.removeNode() 
Firefox中节点没有removeNode方法,必须使用如下方法

  1. node.parentNode.removeChild(node);

22.innerText 
IE支持,FIREFOX不支持 
FF中设置内容文本是用textConent属性.

23. XMLHTTP的区别 
FireFox中的创建方法为:

  1. xmlhttp=new XMLHttpRequest()

而在IE中为:

  1. xmlhttp=new ActiveXObject(”Microsoft.XMLHTTP”)

24. img的src刷新问题 
在IE 下可以用 可以刷新图片,但在FireFox下不行。主要是缓存问题,在地址后面加个随机数就解决了:

  1. myImg.src=this.src+’?'+Math.random();

25. setAttribute()设置属性问题 
IE中很多属性都不能用setAttribute进行设置,但Firefox中却可以,如:

  1. theDiv.setAttribute('style','color:red');
  2. //改为:
  3. object.style.cssText = 'color:red;';
  4. setAttribute('class','styleClass')
  5. //改为:
  6. setAttribute('className','styleClass');
  7. obj.setAttribute('onclick','funcitonname();');
  8. //改为:
  9. obj.onclick=function(){fucntionname();};

...等等

-----------------------------------------------------------------------------------------

IE和FIREFOX在解析CSS方面的区别

1. 对高度的解析 
IE:将根据内容的高度变化,包括未定义高度的图片内容,即使定义了高度,当内容超过高度时,将使用实际高度 
Firefox:没有定义高度时,如果内容中包括了图片内容,Firefox的高度解析是根据印刷标准,这样就会造成和实际内容高度不符合的情况;当定义了高度,但是内容超过高度时,内容会超出定义的高度,但是区域使用的样式不会变化,造成样式错位。
结论:大家在可以确定内容高度的情况下最好定义高度,如果真的没有办法定义高度,最好不用使用边框样式,否则样式肯定会出现混乱!

3.布局问题 
当你在写css的时候,特别是用float: left(或right)排列一窜图片时,会发现在firefox里面正常而IE里面有问题。无论你用margin:0,还是border: 0来约束,都无济于事。
其实这里还有另外一个问题,就是IE对于空格的处理,firefox是忽略的而IE对于块与块之间的空格是处理的。也就是说一个div结束后要紧接着一个div写,中间不要有回车或者空格。不然也许会有问题,比如3px的偏差,而且这个原因很难发现。
非常不走运的是我又碰到了这样的问题,多个img标签连着,然后定义的float: left,希望这些图片可以连起来。但是结果在firefox里面正常而IE里面显示的每个img都相隔了3px。我把标签之间的空格都删除都没有作用。
后来的解决方法是在img外面套li,并且对li定义margin: 0,这样就解决了IE和firefox的显示偏差。IE对于一些模型的解释会产生很多错误问题,只有多多尝试才能发现原因。
这只是一些简单的区别,在做布局和CSS设计时候可以综合考虑,但最为有效与简单的解决兼容问题还是用TABLE表格,表格在兼容性方面有着不错的表现.

4.鼠标样式 
firefox不支持hand,但ie支持pointer 
解决方法: 统一使用pointer

5. padding 问题 
padding 5px 4px 3px 1px FireFox无法解释简写, 
必须改成 padding-top:5px; padding-right:4px; padding-bottom:3px; padding-left:1px;

6. 消除ul、ol等列表的缩进 
消除ul、ol等列表的缩进样式应写成:list-style:none;margin:0px;padding:0px; 
其中margin属性对IE有效,padding属性对FireFox有效

7. CSS透明 
IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。 
FF:opacity:0.6。

8. CSS圆角 
IE:不支持圆角。 
FF: -moz-border-radius:4px,或者 
-moz-border-radius-topleft:4px; 
-moz-border-radius-topright:4px; 
-moz-border-radius-bottomleft:4px; 
-moz-border-radius- bottomright:4px;。

9. CSS双线凹凸边框 
IE:border:2px outset;。 
FF: 
-moz-border-top-colors: #d4d0c8 white; 
-moz-border-left-colors: #d4d0c8 white; 
-moz-border-right-colors:#404040 #808080; 
-moz-border-bottom-colors:#404040 #808080;

10. 滤镜 
IE中支持使用滤镜,而Firefox中不支持.

11. 禁止选取网页内容: 
在IE中一般用js:obj.onselectstart=function(){return false;}; 
而firefox用CSS:-moz-user-select:none;

js获取浏览器窗口属性的更多相关文章

  1. js获取浏览器窗口可视区域大小

    获得浏览器窗口的尺寸(浏览器的视口,不包括工具栏和滚动条)的方法: 一.对于IE9+.Chrome.Firefox.Opera 以及 Safari: •  window.innerHeight - 浏 ...

  2. js获取浏览器窗口的大小

    在我本地测试当中: 在IE.FireFox.Opera下都可以使用 document.body.clientWidth document.body.clientHeight 即可获得,很简单,很方便. ...

  3. 原生JS 获取浏览器、窗口、元素等尺寸的方法及注意事项

    一.通过浏览器获得屏幕的尺寸 screen.width screen.height screen.availHeight //获取去除状态栏后的屏幕高度 screen.availWidth //获取去 ...

  4. js/jquery获取浏览器窗口可视区域高度和宽度以及滚动条高度实现代码

    获取浏览器窗口的可视区域高度和宽度,滚动条高度有需要的朋友可参考一下.IE中,浏览器显示窗口大小只能以下获取: 代码如下复制代码 代码如下: document.body.offsetWidth doc ...

  5. js获取浏览器当前窗口的高度长度

    js获取浏览器可见区域(不包括标题栏.地址栏.收藏夹栏状态栏等额外区域,仅为页面呈现区域)的高度和宽度宽度:document.documentElement.clientWidth高度:documen ...

  6. JS 获取浏览器窗口大小

    JS 获取浏览器窗口大小 <script> // 获取窗口宽度 if (windows.innerWidth) { winWidth = windows.innerWidth; } els ...

  7. JS 获取浏览器和屏幕宽高等信息代码

    JS 获取浏览器和屏幕宽高等信息. 网页可见区域宽:document.body.clientWidth  网页可见区域高:document.body.clientHeight  网页可见区域宽:doc ...

  8. js获取浏览器高度和宽度值,尽量的考虑了多浏览器。

    js获取浏览器高度和宽度值,尽量的考虑了多浏览器. IE中: document.body.clientWidth ==> BODY对象宽度 document.body.clientHeight ...

  9. js获取浏览器基本信息:document.body.clientWidth/clientHeight/scrollWidth/scrollTop。(转)

    js获取浏览器基本信息:document.body.clientWidth/clientHeight/scrollWidth/scrollTop. 分类: js.jquery.ext.js技术2011 ...

随机推荐

  1. 【转】CSDN离线网页html文件自动跳转

    问题: 最近使用OneNote2016剪辑csdn的文章时,发现一些公式/文本框不能被正确识别,所以离线保存网页的html文件. 但是每次打开html文件,都会自动跳转的CSDN主页,即使断网,也会自 ...

  2. Unity3d之Hash&Slash学习笔记之(二)--角色基础类的构建

    Hash&Slash学习笔记之(二)--角色基础类的构建 BaseStat类的构建 基本成员变量: _baseValue //基础属性值 _buffValue //增加的buff值 _expT ...

  3. kali更新后窗口不能适应屏幕的解决方案

    终端执行 systemctl restart open-vm-tools 当然,也可以加入到启动项来实现自启动

  4. CSS快速入门-定位布局(九宫格)

    实现效果图: 看上去是不是很屌的样子?其实实现起来主要就是用到了一个float,不难. 实现步骤:1.新建一个大div,300*30002.里面放5个小div,100*1003.将div定位

  5. UWP 卡片视图 Card View

    上一篇 提到了 UWP 轨道视图Orbit View,这次就说一下卡片视图,毕竟两个差不多. 卡片视图,效果如其名,卡片一样,左右滑动,当然能翻牌最好了. 嗯,我这个可以的额(⊙﹏⊙)... 看下效果 ...

  6. js中哈希表的几种用法总结

    本篇文章只要是对js中哈希表的几种用法进行了总结介绍,需要的朋友可以过来参考下,希望对大家有所帮助 1. <html> <head> <script type=" ...

  7. AssetBundle压缩/内部结构/下载和加载

    一.AssetBundle的压缩方式   Unity支持三种AssetBundle打包的压缩方式:LZMA, LZ4, 以及不压缩.    1.LZMA压缩方式  是一种默认的压缩形式,这种标准压缩格 ...

  8. Unity2018 Shader Graph 实验室

    Unity2018 Shader Graph 实验室 Shader Shader Graph Unity  Tips: -- 在shader forge和amplyfy Shader节点图形化shad ...

  9. BAT面试必备——Java 集合类

    本文首发于我的个人博客:尾尾部落 1. Iterator接口 Iterator接口,这是一个用于遍历集合中元素的接口,主要包含hashNext(),next(),remove()三种方法.它的一个子接 ...

  10. C++可继承的单例基类模板

    目录 一.介绍 二.代码 三.关键处 五.参考资料 一.介绍 最近在写一个项目,其中用到好几个单例,类本身的设计不是很复杂,但是如果每个都写一遍单例又觉得有点冗余:所以查资料写了一个单例基类模板,只要 ...