IE和Firefox的js兼容性整理(2)

作者:zt 来源:老猫的理想 时间:2007-11-21 19:40:00 

变量名与某 HTML 对象 id 相同的问题

(1)现有问题:在 MF 中,因为对象 id 不作为 HTML 对象的名称,所以可以使用与 HTML 对象 id 相同的变量名,IE 中不能。

(2)解决方法:在声明变量时,一律加上 var ,以避免歧义,这样在 IE 中亦可正常运行。
此外,最好不要取与 HTML 对象 id 相同的变量名,以减少错误。

(3)其它:参见 问题4

event.x 与 event.y 问题

(1)现有问题:在IE 中,event 对象有 x, y 属性,MF中没有。

(2)解决方法:在MF中,与event.x 等效的是 event.pageX。但event.pageX IE中没有。
故采用 event.clientX 代替 event.x。在IE 中也有这个变量。vent.clientX 与 event.pageX 有微妙的差别(当整个页面有滚动条的时候),不过大多数时候是等效的。

如果要完全一样,可以稍麻烦些:


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


然后用 mX 代替 event.x

(3)其它:event.layerX 在 IE 与 MF 中都有,具体意义有无差别尚未试验。

关于frame

(1)现有问题:在 IE中 可以用window.testFrame取得该frame,mf中不行

(2)解决方法:在frame的使用方面mf和ie的最主要的区别是:如果在frame标签中书写了以下属性:


<frame src="/blog/xx.htm" id="frameId" name="frameName" />


那么ie可以通过id或者name访问这个frame对应的window对象而mf只可以通过name来访问这个frame对应的window对象。例如如果上述frame标签写在最上层的window里面的htm里面,那么可以这样访问。

ie: window.top.frameId或者window.top.frameName来访问这个window对象;

mf: 只能这样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的内容

关于frame和window的描述可以参见bbs的‘window与frame’文章,以及 /test/js/test_frame/ 目录下面的测试----adun 2004.12.09修改

在mf中,自己定义的属性必须getAttribute()取得,在mf中没有  parentElement parement.children  而用parentNode parentNode.childNodes
childNodes的下标的含义在IE和MF中不同,MF使用DOM规范,childNodes中会插入空白文本节点。一般可以通过node.getElementsByTagName()来回避这个问题。

当html中节点缺失时,IE和MF对parentNode的解释不同,例如


<form>
<table>
<input/>
</table>
</form>


MF中input.parentNode的值为form, 而IE中input.parentNode的值为空节点
MF中节点没有removeNode方法,必须使用如下方法 node.parentNode.removeChild(node)

标签:兼容,Firefox,IE,js
0
投稿

猜你喜欢

  • numpy 实现返回指定行的指定元素的位置索引

    2021-01-19 04:32:27
  • Vue+Echarts实现简单折线图

    2024-05-29 22:42:25
  • 17个asp常用的正则表达式

    2008-01-15 18:58:00
  • 详解vue+webpack+express中间件接口使用

    2024-04-29 13:11:10
  • Python的Django框架中的数据过滤功能

    2022-02-01 05:48:40
  • python实现自动打卡的示例代码

    2022-11-29 15:01:57
  • Vue cli构建及项目打包以及出现的问题解决

    2023-07-02 16:46:46
  • python已协程方式处理任务实现过程

    2022-05-10 03:12:56
  • python 中yaml文件用法大全

    2021-11-30 08:02:29
  • Sql学习第一天——SQL UNION 和 UNION ALL 操作符认识

    2024-01-18 23:33:26
  • 基于Sql Server通用分页存储过程的解决方法

    2024-01-28 01:14:28
  • numpy库reshape用法详解

    2022-02-13 22:00:56
  • 设计提升满意度

    2010-05-16 15:00:00
  • ubuntu20.04 安装 MySQL5.7过程记录

    2024-01-23 20:18:09
  • Python中文件的读取和写入操作

    2023-01-08 22:05:52
  • 微软SQLServer密码管理的危险判断

    2008-11-24 17:34:00
  • Python中设置变量访问权限的方法

    2023-09-13 15:42:15
  • Pycharm远程连接服务器并实现代码同步上传更新功能

    2023-09-20 04:44:40
  • 解决pymysql cursor.fetchall() 获取不到数据的问题

    2024-01-29 09:00:19
  • 详解python pandas 分组统计的方法

    2021-01-30 05:33:48
  • asp之家 网络编程 m.aspxhome.com