1. 对象问题 1.1 Form 对象 现有问题: 现有代码这获得 form 对象通过 document.forms("formName") ,这样使用在 IE 能接受, MF 不能。 解决方法: 改用 作为下标运算。改为 document.forms["formName"] 备注 上述的改用 作为下标运算中的 formName 是 id 而 name 1.2 HTML 对象 现有问题: 在 IE 中, HTML 对象的 ID 可以作为 document 的下属对象变量名直接使用。在 MF 中不能。 document.all("itemName")或者 document.all("itemId") 解决方法: 使用对象 ID 作为对象变量名 document.getElementById("itemId")备注 document.all是 IE 自定义的方法,所以请大家尽量不使用。 还有一种方式,在 IE 和 MF 都可以使用 var f = document.forms["formName "]; var o = f. itemId; 1.3 DIV对象 现有问题: 在 IE 中, DIV 对象可以使用 ID 作为对象变量名直接使用。在 MF 中不能。 DivId.style.display = "none"解决方法: document.getElementById("DivId").style.display = "none"备注 获得对象的方法不管是不是 DIV 对象,都使用 getElementById 方法。参见 1.2 1.4 关于 frame 现有问题 在 IE 中 可以用 window.testFrame 取得该 frame , mf 中不行 解决方法 在 frame 的使用方面 MF 和 IE 的最主要的区别是: 如果在 frame 标签中书写了以下属性: 那么 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 的内容 1.5 窗口 现有问题 IE中可以通过 showModalDialog 和 showModelessDialog 打开模态和非模态窗口,但是 MF 不支持。 解决办法 直接使用 window.open(pageURL,name,parameters) 方式打开新窗口。 如果需要传递参数,可以使用 frame 或者 iframe 。 2. 总结 2.1 在 JS 中定义各种对象变量名时,尽量使用 id ,避免使用 name 。 在 IE 中, HTML 对象的 ID 可以作为 document 的下属对象变量名直接使用。在 MF 中不能,所以在平常使用时请尽量使用 id ,避免只使用 name ,而不使用 id 。 2.2 变量名与某 HTML 对象 id 相同的问题 现有问题 在 MF 中,因为对象 id 不作为 HTML 对象的名称,所以可以使用与 HTML 对象 id 相同的变量名, IE 中不能。 解决方法 在声明变量时,一律加上 var ,以避免歧义,这样在 IE 中亦可正常运行。 此外,最好不要取与 HTML 对象 id 相同的变量名,以减少错误。 1. document.all Firefox可以兼容 document.all , 但会生成一条警告。可以用 getElementById("*") 或者 getElementByTagName("*) 来代替 不过对于 document.all.length 等属性,则完全不兼容。 2. parentElement这个也不兼容。比方说, obj.parentElement.name 则应改成 obj.parentNode.attributes.getNamedItem("name").nodeValue (不知道如何写得更简洁些) 3. event W3C 不支持 windows.event 比方说 : 在 IE 里面
.....
function onMenuClick() { collapseMenu(event.srcElement); } 工作正常。不过在 Firefox 中,则改成:
function onMenuClick(evt) { if(evt == null) evt = window.event; // For IE var srcElement = evt.srcElement? evt.srcElement : evt.target; // IE使用 srcElement, 而 Firefox 使用 target collapseMenu(srcElement); } IE 和 FIREFOX 在解析 CSS 方面的区别 对高度的解析 IE :将根据内容的高度变化,包括未定义高度的图片内容,即使定义了高度,当内容超过高度时,将使用实际高度 Firefox :没有定义高度时,如果内容中包括了图片内容, MF 的高度解析是根据印刷标准,这样就会造成和实际内容高度不符合的情况;当定义了高度,但是内容超过高度时,内容会超出定义的高度,但是区域使用的样式不会变化,造成样式错位。 结论:大家在可以确定内容高度的情况下最好定义高度,如果真的没有办法定义高度,最好不用使用边框样式,否则样式肯定会出现混乱! img 对象 alt 和 title 的解析 alt :当照片不存在或者 load 错误时的提示; title :照片的 tip 说明。 在 IE 中如果没有定义 title , alt 也可以作为 img 的 tip 使用,但是在 MF 中,两者完全按照标准中的定义使用 结论:大家在定义 img 对象时,最后将 alt 和 title 对象都写全,保证在各种浏览器中都能正常使用 其他的细节差别 当你在写 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 表格 , 表格在兼容性方面有着不错的表现 . 另外在模版的 JS 设计的时候也需要考虑两者对代码的兼容 , 以下是对 IE 与 FIREFOX 中 JS 的一些测试 : 以下以 IE 代替 Internet Explorer ,以 MF 代替 Mozilla Firefox 1. document.form.item 问题 (1)现有问题: 现有代码中存在许多 document.formName.item("itemName") 这样的语句,不能 在 MF 下运行 (2)解决方法: 改用 document.formName.elements["elementName"] (3) 其它 参见 2 2. 集合类对象问题 (1)现有问题: 现有代码中许多集合类对象取用时使用 () , IE 能接受, MF 不能。 (2)解决方法: 改用 [] 作为下标运算。如: document.forms("formName") 改为 document.forms["formName"]。 又如: document.getElementsByName("inputName")(1) 改为 document.getElementsByName("inputName")[1] (3)其它 3. window.event (1) 现有问题: 使用 window.event 无法在 MF 上运行 (2)解决方法: MF 的 event 只能在事件发生的现场使用,此问题暂无法解决。可以这样变通: 原代码 ( 可在 IE 中运行 ) : onclick="javascript:gotoSubmit()"/> ... <script language="javascript"> function gotoSubmit() { ... alert(window.event); // use window.event ... } </script> 新代码 ( 可在 IE 和 MF 中运行 ) : onclick="javascript:gotoSubmit(event)"/> ... <script language="javascript"> function gotoSubmit(evt) { evt = evt ? evt : (window.event ? window.event : null); ... alert(evt); // use evt ... } </script>此外,如果新代码中第一行不改,与老代码一样的话 ( 即 gotoSubmit 调用没有给 参数 ) ,则仍然只能在 IE 中运行,但不会出错。所以,这种方案 tpl 部分仍与老 代码兼容。 /////////////////////////////////////////////////////////////////////// // 以下来自网友 llihua // 事件处理函数 function a(evt) { //FireFox evt = evt? evt: window.event; //IE var srcElem = (evt.target)? evt.target: evt.srcElement; //事件处理 ... } 在连接事件处理函数的时候,可以用 Inline HTML 方式,也可以用 Event property 方式定义。 1、使用 Inline HTML 方式,如: onclick="javascript:a(event)">注意: (1)javascript不能省; (2)实参要使用 event ,形参使用什么都可以 ( 如 evt 、 event 等 ) ; 2、使用 Event property 方式绑定事件处理函数,如: document.form2.radio[0].onclick = a; // 以上来自网友 llihua /////////////////////////////////////////////////////////////////////// 4. HTML 对象的 id 作为对象名的问题 (1)现有问题 在 IE 中, HTML 对象的 ID 可以作为 document 的下属对象变量名直接使用。在 MF 中不能。 (2)解决方法 用 getElementById("idName") 代替 idName 作为对象变量使用。 5. 用 idName 字符串取得对象的问题 (1)现有问题 在 IE 中,利用 eval(idName) 可以取得 id 为 idName 的 HTML 对象,在 MF 中不 能。 (2)解决方法 用 getElementById(idName) 代替 eval(idName) 。 6. 变量名与某 HTML 对象 id 相同的问题 (1)现有问题 在 MF 中,因为对象 id 不作为 HTML 对象的名称,所以可以使用与 HTML 对象 id 相同的变量名, IE 中不能。 (2)解决方法 在声明变量时,一律加上 var ,以避免歧义,这样在 IE 中亦可正常运行。 此外,最好不要取与 HTML 对象 id 相同的变量名,以减少错误。 (3)其它 参见 问题 4 7. event.x 与 event.y 问题 (1)现有问题 在 IE 中, event 对象有 x, y 属性, MF 中没有。 (2)解决方法 在 MF 中,与 event.x 等效的是 event.pageX 。但 event.pageX IE 中没有。 故采用 event.clientX 代替 event.x 。在 IE 中也有这个变量。 event.clientX 与 event.pageX 有微妙的差别(当整个页面有滚动条的时候), 不过大多数时候是等效的。 如果要完全一样,可以稍麻烦些: mX = event.x ? event.x : event.pageX;然后用 mX 代替 event.x (3) 其它 event.layerX 在 IE 与 MF 中都有,具体意义有无差别尚未试验。 8. 关于 frame (1) 现有问题 在 IE 中 可以用 window.testFrame 取得该 frame , mf 中不行 (2)解决方法 在 frame 的使用方面 mf 和 ie 的最主要的区别是: 如果在 frame 标签中书写了以下属性: <frame src="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修改 9. 在 mf 中,自己定义的属性必须 getAttribute() 取得 10.在 mf 中没有 parentElement parement.children 而用 parentNode parentNode.childNodes childNodes的下标的含义在 IE 和 MF 中不同, MF 使用 DOM 规范, childNodes 中会插入空白 文本节点。 一般可以通过 node.getElementsByTagName() 来回避这个问题。 当 html 中节点缺失时, IE 和 MF 对 parentNode 的解释不同,例如
MF中 input.parentNode 的值为 form, 而 IE 中 input.parentNode 的值为空节点 MF 中节点没有 removeNode 方法,必须使用如下方法 node.parentNode.removeChild(node) 11.const 问题 (1)现有问题 : 在 IE 中不能使用 const 关键字。如 const constVar = 32; 在 IE 中这是语法错误。 (2)解决方法 : 不使用 const ,以 var 代替。 12. body 对象 MF的 body 在 body 标签没有被浏览器完全读入之前就存在,而 IE 则必须在 body 完全被读入 之后才存在 13. url encoding 在 js 中如果书写 url 就直接写 & 不要写 & 例如 var url = 'xx.jsp?objectName=xx&objectEvent=xxx'; frm.action = url那么很有可能 url 不会被正常显示以至于参数没有正确的传到服务器 一般会服务器报错参数没有找到 当然如果是在 tpl 中例外,因为 tpl 中符合 xml 规范,要求 & 书写为 & 一般 MF 无法识别 js 中的 & 14. nodeName 和 tagName 问题 (1)现有问题: 在 MF 中,所有节点均有 nodeName 值,但 textNode 没有 tagName 值。在 IE 中, nodeName 的使用好象 有问题(具体情况没有测试,但我的 IE 已经死了好几次)。 (2)解决方法: 使用 tagName ,但应检测其是否为空。 15. 元素属性 IE下 input.type 属性为只读,但是 MF 下可以修改 16. document.getElementsByName() 和 document.all[name] 的问题 (1)现有问题: 在 IE 中, getElementsByName() 、 document.all[name] 均不能用来取得 div 元素 (是否还有其它不能取的元素还不知道)。 17. DOM 数据岛的问题 (1)现有问题 在 IE 中 , , 这其中和是简写形式的 , 会使 MF 无法识别 , 应当写成 : 不过 , 我怀疑如果用 XHTML, 可能就没有这种问题 . 但我还没有试过 . 对于 IE 中