知识大全 ie与火狐中常见的兼容问题

Posted

篇首语:仰天大笑出门去,我辈岂是蓬蒿人。本文由小常识网(cha138.com)小编为大家整理,主要介绍了知识大全 ie与火狐中常见的兼容问题相关的知识,希望对你有一定的参考价值。

   document form item 问题

  ( )现有问题

  现有代码中存在许多 document formName item("itemName") 这样的语句 不能在Firefox(火狐)下运行

  ( )解决方法

  改用 document formName elements["elementName"]

   集合类对象问题

  ( )现有问题

  现有代码中许多集合类对象取用时使用 () IE 能接受 Firefox(火狐)不能

  ( )解决方法

  改用 [] 作为下标运算 如

  document forms("formName") 改为 document forms["formName"]

  又如

  document getElementsByName("inputName")( ) 改为document getElementsByName("inputName")[ ]

   window event

  ( )现有问题

  使用 window event 无法在火狐浏览器上运行

  ( )解决方法

  火狐 的 event 只能在事件发生的现场使用 此问题暂无法解决 可以这样变通

  原代码(可在IE中运行)

    

  新代码(可在IE和火狐中运行)

    

  此外 如果新代码中第一行不改 与老代码一样的话(即 gotoSubmit 调用没有给参数) 则仍然只能在IE中运行 但不会出错 所以 这种方案 tpl 部分仍与老代码兼容

   HTML 对象的 id 作为对象名的问题

  ( )现有问题

  在 IE 中 HTML 对象的 ID 可以作为 document 的下属对象变量名直接使用 在火狐中不能

  ( )解决方法

  用 getElementById("idName") 代替 idName 作为对象变量使用

   用idName字符串取得对象的问题

  ( )现有问题

  在IE中 利用 eval(idName) 可以取得 id 为 idName 的 HTML 对象 在火狐中不能

  ( )解决方法

  用 getElementById(idName) 代替 eval(idName)

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

  ( )现有问题

  在火狐中 因为对象 id 不作为 HTML 对象的名称 所以可以使用与 HTML 对象 id 相同的变量名 IE中能

  ( )解决方法

  在声明变量时 一律加上 var 以避免歧义 这样在 IE 中亦可正常运行

  此外 最好不要取与 HTML 对象 id 相同的变量名 以减少错误

   event x 与 event y 问题

  ( )现有问题

  在IE 中 event 对象有 x y 属性 火狐中没有

  ( )解决方法

  在火狐中 与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

  ( )其它

  event layerX 在IE与火狐中都有 具体意义有无差别尚未试验

   关于frame

  ( )现有问题

  在 IE中 可以用window testFrame取得该frame 火狐中不行

  ( )解决方法

  在frame的使用方面火狐和ie的最主要的区别是

  如果在frame标签中书写了以下属性

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

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

  火狐 只能这样window top frameName来访问这个window对象

  另外 在火狐和ie中都可以使用 window top document getElementById("frameId")来访问frame标签 并且可以通过window top document getElementById("testFrame") src = xx 来切换frame的内容 也都可以通过window top frameName location = xx 来切换frame的内容 关于frame和window的描述可以参见bbs的‘window与frame’文章 以及/test/js/test_frame/目录下面的测试

   在火狐中 自己定义的属性必须getAttribute()取得

   在火狐中没有 parentElement parement children 而用

  parentNode parentNode childNodes childNodes的下标的含义在IE和火狐中不同 火狐使用DOM规范 childNodes中会插入空白文本节点

  一般可以通过node getElementsByTagName()来回避这个问题

  当中节点缺失时 IE和火狐对parentNode的解释不同 例如

  <form> <table> <input/> </table> </form> 火狐中input parentNode的值为form 而IE中input parentNode的值为空节点

  火狐中节点没有removeNode方法 必须使用如下方法 node parentNode removeChild(node)

   const 问题

  ( )现有问题:

  在 IE 中不能使用 const 关键字 如 const constVar = ; 在IE中这是语法错误

  ( )解决方法:

  不使用 const 以 var 代替

   body 对象

  火狐的body在body标签没有被浏览器完全读入之前就存在 而IE则必须在body完全被读入之后才存在

   url encoding

  在js中如果书写url就直接写&不要写&例如var url = xx jsp?objectName=xx&objectEvent=xxx ; frm action = url那么很有可能url不会被正常显示以至于参数没有正确的传到服务器 一般会服务器报错参数没有找到 当然如果是在tpl中例外 因为tpl中符合xml规范 要求&书写为& 一般火狐无法识别js中的&

   nodeName 和 tagName 问题

  ( )现有问题

  在火狐中 所有节点均有 nodeName 值 但 textNode 没有 tagName 值 在 IE 中 nodeName 的使用好象 有问题(具体情况没有测试 但我的IE已经死了好几次)

  ( )解决方法

  使用 tagName 但应检测其是否为空

   元素属性

  IE下 input type属性为只读 但是火狐下可以修改

   document getElementsByName() 和 document all[name] 的问题

  ( )现有问题

  在 IE 中 getElementsByName() document all[name] 均不能用来取得 div 元素(是否还有其它不能取的元素还不知道)

   最简单的鼠标移过手变型的css要改了

  cursor:pointer;/*ff不支持cursor:hand*/ dw 下面自动出来的也没有hand这个属性了 标准的是pointer

   ff不支持滤镜 最常见的半透明不支持

  filter: Alpha(Opacity= ); /* for IE */ opacity: ;/* for Firefox */

   onmouseover="this style MozOpacity= ; this filters alpha opacity= " onmouseout="this style MozOpacity= ; this filters alpha opacity= "

   ff不支持expression 例如去掉链接的边框要分别写不同的css

  a area blr:expression(this onFocus=this blur()) /* for IE */ :focus outline: none; /* for Firefox */

   ff不支持div滚动条的颜色设置 目前还没有找到替换的 好方法

   contendiv position: absolute; left: px; top: px; width: px;height: px; line height: %;text align:left; font family:"宋体";word break : break all; color:# D E ; OVERFLOW Y:auto;OVERFLOW X:no; SCROLLBAR ARROW COLOR: red; SCROLLBAR TRACK COLOR: F F F ;SCROLLBAR FACE COLOR:#F F F ;SCROLLBAR SHADOW COLOR:#F F F ; SCROLLBAR DARKSHADOW COLOR:#F F F ;SCROLLBAR DLIGHT COLOR:#F F F ;SCROLLBAR HIGHLIGHT COLOR:#F F F ; 这个在ff里面完全没有效果了

   ie下面显示在文字下面横线的

  border width: px px px px;在ff里面跑到文字上面去了 (查了手册还是没有找到解决的办法感觉莫名奇妙~~ 原来是ff的容错能力太差了 是下面的width: px;height: px;宽高 引起的 其实a:haver已经继承了上级的属性了 只要定义不同的样式就可以了 看来ff有助于制作标准化 简洁化的网页啊 对css的理解也更深刻 对提供css来说是个很好的帮助)

   onelinksdiv a:hover display: block;border style: solid;color: #ff ;border width: px px px px; /* display: block;border style: solid; border width: px px px px; width: px;height: px; color: #ff ; font size: px;text align: right; */

  //下面的写法在ie下面正常 但在ff下是错误的

   onelinksdiv a:hover display: block;border: #ff solid; border width: px px px px; width: px;height: px; color: #ff ; font size: px;text align: right;

  相关参考资料

   border width:border top width border right width border bottom width border left width; p#fourborders border width:thick medium thin px;

  如果定义四个值 那么这四个值就分别是上 右 下 左边框的宽度值(从上边框开始 以逆时针的顺序遍历)

  等价于下面的定义

  p#fourborders border top width:thick; border right width:medium; border bottom width:thin; border left width: px;

   ff不支持<body scroll="no" > scroll属性

  必须定义overflow:hidden;而且要在标签下 不能在 body下

   overflow:hidden;

   ff不支持数据岛绑定

  <xml id="news" src=news xml ></xml>在ie下可以加载进数据 但到了火狐就加载不进数据了 开始以为可能是因为内容行文字太多导致不能断行不能加载 但删除 只剩几个字以后一样不行

  

  在网页中的单元 格里的内容超出一行时 在ie浏览器里定义的换行样式能够正常使 用 但在firefox里却不能被支持了 是MS扩展的IE专有属性 并未成为W C标准 因而 Firefox 还不能支持它 不过MS已经将其提交到了W C 而在W C的CSS 的候选方案中也能看到它 希望这个属性在被W C最终定案的为CSS 标准 后 Firefox可以支持吧 这之前 可以试试 (当它是英文的时候就不能正常换行了)

   目前FF 为止都不支持IE的name锚点

  像这种写法都是不支持的 <a href="###" onclick="history go( )">go back</a> 原来根据W C的语法 <a>标签始终都会查找href地址并跳转过去 现在onclick事件与###这个地址又有冲突

  为了让Firefox与IE部分元素属性兼容 那个费劲 我无意中发现 Firefox对空格敏感

  <a onclick="window location href=faq php?page=messages# "> //有空格 锚点作用 <a onclick="window location faq php?page=messages# "> //无空格 锚点无作用 锚点的写法又十分讲究 比如<a name=# > Firefox不支持锚点 得加上id=# 静态同页面引用时必须这样写 <a href="# "></a> <a href="static # "></a>就不行****态页面要用JS

  后遗症来了 考虑到鼠标样式和浏览器兼容又开始折腾

  <a href="###" onclick=""> //不兼容 <a href="javascript:;" onclick=""> //不兼容 <a href="javascript:function();"> //没有 属于脚本的非法书写 <a onclick=""> //没照顾到自定义系统鼠标样式的用户 <a href="javascript:)" 本以为火狐浏览器使用的人很多 但从网站的统计分析来看火狐只有可怜的 % 但兼容他的标准确花费不少精力!不过标准化有利于以后的维护和扩展 有利于技术的不断提示 >

cha138/Article/program/PHP/201311/21315

相关参考

知识大全 JS的IE和Firefox兼容性汇编

JS的IE和Firefox兼容性汇编  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!  以下以IE代

知识大全 用js实现table单元格高宽调整,兼容合并单元格(兼容IE6、7、8、FF)实例

用js实现table单元格高宽调整,兼容合并单元格(兼容IE6、7、8、FF)实例  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内

知识大全 jquery实现图片渐变切换兼容ie6/Chrome/Firefox

jquery实现图片渐变切换兼容ie6/Chrome/Firefox  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快

知识大全 如何在JSP上放置兼容Firefox、IE、Chrome的applet

如何在JSP上放置兼容Firefox、IE、Chrome的applet  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶

知识大全 手机百度浏览器怎么改成兼容模式

手机百度浏览器怎么改成兼容模式手机没有双核浏览器,所以没有兼容模式,并且兼容模式指的是IE内核,现在IE并无安卓或者苹果版的浏览器,所以也没法对手机做出兼容模式。在电脑中,Windows为程序提供了一

知识大全 JS 两日期相减,获得天数的小例子(兼容IE,FF)

JS两日期相减,获得天数的小例子(兼容IE,FF)  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!这

知识大全 js获得指定控件输入光标的坐标兼容IE等多种主流浏览器

js获得指定控件输入光标的坐标兼容IE等多种主流浏览器  以下文字资料是由(全榜网网www.cha138.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧

知识大全 单击复制文字兼容各浏览器的完美解决方案

  单击复制文字的js找了很久由于之前没有接触过完全不知道兼容ie及标准dom浏览器不仅仅要通过js而且需要flash的帮忙clipboardswf这个在网上都有下载ie允许访问剪贴板windowcl

知识大全 火狐textarea输入法的bug的触发及解决

在firefox中如果一个textarea获取焦点在输入法激活的状态如果这时js将该textarea的value修改那么该textarea会直接被清空下面是具体的解决方法遇到类似问题的朋友可以参考下&

知识大全 网页最简短的拖动对象代码实例演示

  以前在网上看到的最简单的拖动对象的代码忘记作者叫什么了原始代码在IE下有些小问题并且声明了文档类型为x后在FF等非IE浏览器下无效对其进行了改进现在已经可兼容:IEFirefoxOpera<