`
jackie9305
  • 浏览: 39092 次
  • 性别: Icon_minigender_1
  • 来自: 福建
社区版块
存档分类
最新评论

JavaScript在IE和firefox中一些不通用的属性和方法

阅读更多
以下以 IE 代替 Internet Explorer,以 MF 代替 Mozzila 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中运行): ... 新代码(可在IE和MF中运行): ... 此外,如果新代码中第一行不改,与老代码一样的话(即 gotoSubmit 调用没有给参数),则仍然只能在IE中运行,但不会出错。所以,这种方案 tpl 部分仍与老代码兼容。 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标签中书写了以下属性: 那么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 元素(是否还有其它不能取的元素还不知道)。 -------------------------------------------------------------------------------------------------------- 发现几处IE与firefox的js和css几处不同点2007-09-08 23:11终于完成了偶的拖动窗口,花了近15个小时,庆祝一下(*^__^*);以前写了IE下的功能,于是又写了firefox下的功能,在firefox上花了很多时间,发现了firefox中几处与IE中不同的地方: 1.firefox不能对innerText支持,也不知道为什么。firefox支持innerHTML但却不支持innerText,所以上网查了一下,原来它改支持textContent来实现innerText,不过实现得没有那么好,默认把多余的空格也保留了。如果不用textContent,如果字符串里面不包含HTML代码也可以用innerHTML代替 2.禁止选取网页内容: 在IE中一般用js:obj.onselectstart=function(){return false;} 而firefox用CSS:-moz-user-select:none 3.滤镜的支持(例:透明滤镜): IE:filter:alpha(opacity=10); firefox:-moz-opacity:.10; 4.捕获事件: IE:obj.setCapture() 、obj.releaseCapture() Firefox: document.addEventListener("mousemove",mousemovefunction,true);     document.removeEventListener("mousemove",mousemovefunction,true); 5.获取鼠标位置: IE:event.clientX、event.clientY firefox:需要事件函数传递事件对象     obj.onmousemove=function(ev){      X= ev.pageX;Y=ev.pageY;     } 6.DIV等元素的边界问题: 比如:设置一个div的CSS::{width:100px;height:100px;border:#000000 1px solid;} IE中:div的宽度(包括边框宽度):100px,div的高度(包括边框宽度):100px; 而firefox:div的宽度(包括边框宽度):102px,div的高度(包括边框宽度):102px; 所以在做这个兼容IE和firefox的拖动窗口时,在js和css的写法上要动点脑筋,给大家两个小技巧 一.判断浏览器类型: var isIE=document.all? true:false; 我写了一个变量,如果支持document.all语法那么isIE=true,否则isIE=false 二.在不同浏览器下的CSS处理: 一般可以用!important来优先使用css语句(仅firefox支持) 比如:{border-width:0px!important;border-width:1px;} 在firefox下这个元素是没有边框的,在IE下边框宽度是1px 又发现几处XHTML与正常状态下的JS、CSS的区别 前阶段写了兼容IE/Firefox的拖动窗口发现了这两个浏览器的几处区别:发现几处IE与firefox的js和css几处不同点【原】 今天又写了兼容XHTML的版本,因为现在不是流行web标准嘛,偶不能落后啊!再说现在ASP.NET中的所有页面都是应用XHTML标准的,如果在布局页面中删了这句标准代码,里面的布局和控件visual studio就不显示了。 呵呵,在网页开头加了这个代码就是所谓的XHTML标准了<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 改了一下JS和CSS,调试了N次,发现了XHTML标准下的几个不同点: 1.document.documentElement 与 document.body 代码中设置页面的CSS时一定要用:document.documentElement 比如:document.documentElement.style.overflow='hidden'; overflow-X、overflow-Y 这两个分坐标属性XHTML是不支持的; 2.在取得网页窗口区域和获取滚动条位移距离时也要用document.documentElement 即这四个属性(clientWidth、clientHeight、scrollLeft、scrollTop)一定要用document.documentElement 但是document.body.appendChild()和document.body.removeChild()却是可以用的,而且用document.documentElement.appendChild()和document.documentElement.removeChild()代替却会报错; **********所以我总结了一下仅clientWidth、clientHeight、scrollLeft、scrollTop和document.documentElement.style时才用document.documentElement 3.呵呵,加了这个标准以后IE的边框问题也出现了变化,现在和firefox趋于一致了,是不是这个就是XHTML的优点——跨浏览器的标准 上篇文章提到: 设置一个div的CSS::{width:100px;height:100px;border:#000000 1px solid;} IE中(正常情况):div的宽度(包括边框宽度):100px,div的高度(包括边框宽度):100px; firefox(正常情况)::div的宽度(包括边框宽度):102px,div的高度(包括边框宽度):102px; 加了XHTML标准后的(IE和firefox打和了,^_^): IE中(XHTML):div的宽度(包括边框宽度):102px,div的高度(包括边框宽度):102px; firefox(XHTML)::div的宽度(包括边框宽度):102px,div的高度(包括边框宽度):102px; ------------------------------------------------------------------------------------------ 应用背景: 需要打开一个子窗体,将需要修改的数据传到子窗体,然后将子窗体中修改过的数据,传回父窗体。(父窗体不能被刷新) 例如:父窗体只供用户查看,子窗体用于修改。 方法: 父窗体: dim xxx '返回值 dim yyy '传到子窗体的参数 var xxx = ShowModalDialog('xxx.asp','yyy','dialogWidth:100px;DialogHeight=290px;status:no') 子窗体: dim yyy '从父窗体传来的参数 dim xxx '传回父窗体的参数 yyy = window.dialogArguments xxx = window.returnValue 原文地址为http://blog.csdn.net/lgh731/archive/2009/03/11/3978735.aspx
分享到:
评论

相关推荐

    javascript在IE和Firefox中兼容性问题

    本文将深入探讨在IE和Firefox中常见的JavaScript兼容性问题,旨在帮助开发者了解并解决这些差异带来的挑战。 #### 一、DOM元素获取的兼容性差异 1. **`document.all`与`document.getElementsByName`和`...

    javascript在firefox与ie下的兼容性总结

    JavaScript在Firefox和IE之间的兼容性问题一直是前端开发者面临的一大挑战。由于这两个浏览器内核的不同,导致在处理某些JavaScript特性时存在差异。以下是一些常见的兼容性问题及其解决方案: 1. **Document.form....

    js在IE和Firefox不同之处

    ### js在IE和Firefox不同之处 在Web开发中,JavaScript(简称JS)是实现网页交互性的核心语言之一。然而,由于不同的浏览器对于JS标准的支持程度有所差异,这往往会导致跨浏览器兼容性问题的出现。IE(Internet ...

    DOM文档和Javascript的IE和Firefox兼容性

    - 在IE中,`document.all`属性可以用来获取所有HTML元素,而在Firefox和其他遵循W3C标准的浏览器中,应使用`document.getElementsByTagName`或者`document.querySelector`等方法。 - `getElementById`在所有主流...

    IE和FIREFOX的JAVASCRIPT兼容性总结.pdf

    在Web开发中,JavaScript的兼容性是至关重要的,尤其是在IE(Internet Explorer)和Firefox这两个浏览器之间。由于它们对JavaScript的实现存在显著差异,开发者需要掌握这些差异并采取适当的兼容处理措施。以下是...

    IE和Firefox中J avaScript兼容

    本文将详细介绍在IE与Firefox浏览器之间实现JavaScript脚本兼容的方法,主要涉及函数、属性、方法等方面的内容。 #### 1. 获取表单元素 - **IE**: 支持`document.formName.item("itemName")`和`document.formName....

    IE和Firefox的Javascript兼容性总结终版.pdf

    JavaScript兼容性问题一直是Web开发中的一个痛点,尤其是在处理IE与Firefox之间差异时。本文将深入探讨两者在JavaScript函数和方法、样式访问和设置、DOM操作、事件处理以及其他方面的兼容性处理,帮助开发者解决跨...

    ie与火狐中常见的一些兼容问题.doc

    这种方式可以在多种浏览器中通用,包括Internet Explorer(IE)和Firefox。 #### 2. 集合类对象问题 - **现有问题**:使用括号`()`来访问集合类对象中的元素时,IE可以正常解析并执行,但在Firefox中则会报错。 ...

    ie firefox 兼容问题大全

    - **问题描述**:在IE和部分版本的Firefox中,可以通过`window.location`或`window.location.href`获取当前页面的URL;但在某些旧版本的Firefox中,只能使用`window.location`。 - **解决方案**:建议始终使用`...

    JS的IE和Firefox兼容性

    JavaScript在不同浏览器之间的兼容性问题一直是开发者面临的重要挑战,尤其是早期的Internet Explorer(IE)和Mozilla Firefox(MF)之间存在显著差异。以下是一些关键的兼容性问题及其解决方案: 1. **document....

    兼容IE与FireFox

    由于IE和Firefox在事件对象的获取上有差异,我们需要编写一段通用的代码来适应这两种情况。以下是一段示例代码: ```javascript function test(event) { var event = event || window.event; // doSomething } ``...

    js firefox支持问题

    - **使用`document.formName.elements["elementName"]`**:这是一种更通用且符合W3C标准的方法,同时在IE和Firefox中都得到良好支持。 #### 2. 数组操作 - **在使用数组时需注意**:在处理如`document.forms["form...

    BlueBala » 兼容IE和Firefox的事件模型(拖动)

    在IE中,我们可以通过`onmousedown`、`onmousemove`和`onmouseup`事件来实现拖动,而在Firefox中,我们可以使用`addEventListener`添加这些事件的监听器。但这样的做法会导致代码的不兼容性,因为IE不支持`...

    Javascript在IE和Mozilla中的兼容性问题.doc

    然而,由于不同浏览器对JavaScript的支持程度和实现方式存在差异,尤其是在早期版本的Internet Explorer(IE)和Mozilla Firefox(MF)之间,开发者经常遇到兼容性问题。以下是一些常见的JavaScript在IE和MF中的兼容...

    IE&FireFox;的JS区别

    - 在IE中,可以通过`window.event`获取当前事件对象,而Firefox不支持此方法。为实现跨浏览器兼容,可以在事件处理函数中传递`event`参数,如`onclick="javascript:gotoSubmit(event)"`,然后在函数内部判断并使用`...

    火狐与IE浏览器之间的一些差别收集.docx

    #### 一、IE与Firefox的JavaScript和CSS差异 在Web开发过程中,不同的浏览器对于JavaScript和CSS的支持程度各不相同,这往往导致了网页在不同浏览器下的表现差异。以下是针对Internet Explorer(简称IE)与Mozilla ...

    IE与火狐常见的区别

    了解不同浏览器之间的差异至关重要,尤其在处理Internet Explorer(IE)与Mozilla Firefox(火狐)时,由于两者对某些CSS属性和HTML标签的支持程度不同,开发者常需采取特定策略以确保网页在各种浏览器中的兼容性和...

    javascript 同时在IE和FireFox获取KeyCode的代码

    本文将详细解析如何在IE和Firefox浏览器中同时获取键盘事件的keyCode值。 ### IE和Firefox在键盘事件处理上的差异 IE浏览器使用window.event.keyCode来获取被按下的键的键码值。window.event是一个全局事件对象,...

    ie6,ie7,ie8和firefox下兼容的图片上传预览

    本话题将深入探讨如何在这些古老的IE版本和Firefox浏览器上实现图片上传预览功能。 图片上传预览是指在用户选择文件后,不实际上传,而是即时在页面上显示所选图片的预览效果,这样可以提高用户体验,让用户在上传...

Global site tag (gtag.js) - Google Analytics