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

上传人:b****3 文档编号:11209094 上传时间:2023-05-29 格式:DOCX 页数:24 大小:29.46KB
下载 相关 举报
火狐与IE浏览器之间的一些差别.docx_第1页
第1页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第2页
第2页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第3页
第3页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第4页
第4页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第5页
第5页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第6页
第6页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第7页
第7页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第8页
第8页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第9页
第9页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第10页
第10页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第11页
第11页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第12页
第12页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第13页
第13页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第14页
第14页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第15页
第15页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第16页
第16页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第17页
第17页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第18页
第18页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第19页
第19页 / 共24页
火狐与IE浏览器之间的一些差别.docx_第20页
第20页 / 共24页
亲,该文档总共24页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

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

《火狐与IE浏览器之间的一些差别.docx》由会员分享,可在线阅读,更多相关《火狐与IE浏览器之间的一些差别.docx(24页珍藏版)》请在冰点文库上搜索。

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

火狐与IE浏览器之间的一些差别

查看文章

火狐与IE浏览器之间的一些差别收集2009-09-1410:

26一、IE与FireFox的js和css

png透明AlphaImageLoader

filter:

progid:

DXImageTransform.Microsoft.AlphaImageLoader(enabled=bEnabled,sizingMethod=sSize,src=sURL)

enabled:

可选项。

布尔值(Boolean)。

设置或检索滤镜是否激活。

true:

默认值。

滤镜激活。

false:

滤镜被禁止。

sizingMethod:

可选项。

字符串(String)。

设置或检索滤镜作用的对象的图片在对象容器边界内的显示方式。

crop:

剪切图片以适应对象尺寸。

image:

默认值。

增大或减小对象的尺寸边界以适应图片的尺寸。

scale:

缩放图片以适应对象的尺寸边界。

src:

必选项。

字符串(String)。

使用绝对或相对url地址指定背景图像。

假如忽略此参数,滤镜将不会作用。

firefox不能对innerText支持

firefox支持innerHTML但却不支持innerText,它支持textContent来实现innerText,不过默认把多余的空格也保留了。

如果不用textContent,如果字符串里面不包含HTML代码也可以用innerHTML代替。

禁止选取网页内容

在IE中一般用js:

obj.onselectstart=function(){returnfalse;}

而firefox用CSS:

-moz-user-select:

none

滤镜的支持(例:

透明滤镜)

IE:

filter:

alpha(opacity=10);

firefox:

-moz-opacity:

.10;

捕获事件

IE:

obj.setCapture()、obj.releaseCapture()

Firefox:

document.addEventListener(”mousemove”,mousemovefunction,true);

document.removeEventListener(”mousemove”,mousemovefunction,true);

获取鼠标位置

IE:

event.clientX、event.clientY

firefox:

需要事件函数传递事件对象

obj.onmousemove=function(ev){

X=ev.pageX;Y=ev.pageY;

}

DIV等元素的边界问题

比如:

设置一个div的CSS:

{width:

100px;height:

100px;border:

#0000001pxsolid;}

IE中:

div的宽度(包括边框宽度):

100px,div的高度(包括边框宽度):

100px;

而firefox:

div的宽度(包括边框宽度):

102px,div的高度(包括边框宽度):

102px;

判断浏览器类型

varisIE=document.all?

true:

false;

我写了一个变量,如果支持document.all语法那么isIE=true,否则isIE=false

在不同浏览器下的CSS处理

一般可以用!

important来优先使用css语句(仅firefox支持)

比如:

{border-width:

0px!

important;border-width:

1px;}

在firefox下这个元素是没有边框的,在IE下边框宽度是1px

document.formName.item(”itemName”)问题

问题说明:

IE下,可以

使用document.formName.item(”itemName”)或document.formName.elements

[”elementName”];Firefox下,只能使用document.formName.elements[”elementName”]。

解决方法:

统一使用document.formName.elements[”elementName”]。

集合类对象问题

问题说明:

IE下,可以使用()或[]获取集合类对象;Firefox下,只能使用[]获取集合类对象。

解决方法:

统一使用[]获取集合类对象。

自定义属性问题

问题说明:

IE下,可以使用获取常规属性的方法来获取自定义属性,也可以使用getAttribute()获取自定义属性;Firefox下,只能使用getAttribute()获取自定义属性。

解决方法:

统一通过getAttribute()获取自定义属性。

eval(”idName”)问题

问题说明:

IE下,可以使用eval(”idName”)或

getElementById(”idName”)来取得id为idName的HTML对象;Firefox下,只能使用

getElementById(”idName”)来取得id为idName的HTML对象。

解决方法:

统一用getElementById(”idName”)来取得id为idName的HTML对象。

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

问题说明:

IE下,HTML对象的ID可以作为document的下属对象变量名直接使用,Firefox下则不能;Firefox下,可以使用与HTML对象ID相同的变量名,IE下则不能。

解决方法:

使用document.getElementById(”idName”)代替document.idName。

最好不要取HTML对象ID相同的变量名,以减少错误;在声明变量时,一律加上var关键字,以避免歧义。

const问题

问题说明:

Firefox下,可以使用const关键字或var关键字来定义常量;IE下,只能使用var关键字来定义常量。

解决方法:

统一使用var关键字来定义常量。

input.type属性问题

问题说明:

IE下input.type属性为只读;但是Firefox下input.type属性为读写。

解决办法:

不修改input.type属性。

如果必须要修改,可以先隐藏原来的input,然后在同样的位置再插入一个新的input元素。

window.event问题

问题说明:

window.event只能在IE下运行,而不能在Firefox下运行,这是因为Firefox的event只能在事件发生的现场使用。

解决方法:

在事件发生的函数上加上event参数,在函数体内(假设形参为evt)使用varmyEvent=evt?

evt:

(window.event?

window.event:

null)

示例:

functiondoSomething(evt){

varmyEvent=evt?

evt:

(window.event?

window.event:

null)

}

event.x与event.y问题

问题说明:

IE下,even对象有x、y属性,但是没有pageX、pageY属性;Firefox下,even对象有pageX、pageY属性,但是没有x、y属性。

解决方法:

varmyX=event.x?

event.x:

event.pageX;varmyY=event.y?

event.y:

event.pageY;

如果考虑第8条问题,就改用myEvent代替event即可。

event.srcElement问题

问题说明:

IE下,even对象有srcElement属性,但是没有target属性;Firefox下,even对象有target属性,但是没有srcElement属性。

解决方法:

使用srcObj=event.srcElement?

event.srcElement:

event.target;

如果考虑第8条问题,就改用myEvent代替event即可。

window.location.href问题

问题说明:

IE或者Firefox2.0.x下,可以使用window.location或window.location.href;Firefox1.5.x下,只能使用window.location。

解决方法:

使用window.location来代替window.location.href。

当然也可以考虑使用location.replace()方法。

模态和非模态窗口问题

问题说明:

IE下,可以通过showModalDialog和showModelessDialog打开模态和非模态窗口;Firefox下则不能。

解决方法:

直接使用window.open(pageURL,name,parameters)方式打开新窗口。

果需要将子窗口中的参数传递回父窗口,可以在子窗口中使用window.opener来访问父窗口。

如果需要父窗口控制子窗口的话,使用var

subWindow=window.open(pageURL,name,parameters);来获得新开的窗口对象。

frame和iframe问题

以下面的frame为例:

(1)访问frame对象

IE:

使用window.frameId或者window.frameName来访问这个frame对象;

Firefox:

使用window.frameName来访问这个frame对象;

解决方法:

统一使用window.document.getElementById(”frameId”)来访问这个frame对象;

(2)切换frame内容

在IE和Firefox中都可以使用window.document.getElementById(”frameId”).src=“xxx.html”或window.frameName.location=“xxx.html”来切换frame的内容;

如果需要将frame中的参数传回父窗口,可以在frame中使用parent关键字来访问父窗口。

body载入问题

问题说明:

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

[注]这个问题尚未实际验证,待验证后再来修改。

[注]经验证,IE6、Opera9以及FireFox2中不存在上述问题,单纯的JS脚本可以访问在脚本之前已经载入的所有对象和元素,即使这个元素还没有载入完成。

事件委托方法

问题说明:

IE下,使用document.body.onload=inject;其中functioninject()在这之前已被实现;在Firefox下,使用document.body.onload=inject();

解决方法:

统一使用document.body.onload=newFunction(”inject()”);或者document.body.onload=function(){/*这里是代码*/}

[注意]Function和function的区别

访问的父元素的区别

问题说明:

在IE下,使用obj.parentElement或obj.parentNode访问obj的父结点;在firefox下,使用obj.parentNode访问obj的父结点。

解决方法:

因为firefox与IE都支持DOM,因此统一使用obj.parentNode来访问obj的父结点。

cursor:

handVScursor:

pointer

问题说明:

firefox不支持hand,但ie支持pointer,两者都是手形指示。

解决方法:

统一使用pointer。

innerText的问题

问题说明:

innerText在IE中能正常工作,但是innerText在FireFox中却不行。

解决方法:

在非IE浏览器中使用textContent代替innerText。

示例:

if(navigator.appName.indexOf(”Explorer”)>-1){

document.getElementById(”element”).innerText=“mytext”;

}else{

document.getElementById(”element”).textContent=“mytext”;

}

[注]innerHTML同时被ie、firefox等浏览器支持,其他的,如outerHTML等只被ie支持,最好不用。

对象宽高赋值问题

问题说明:

FireFox中类似obj.style.height=imgObj.height的语句无效。

解决方法:

统一使用obj.style.height=imgObj.height+“px”;

Table操作问题

问题说明:

ie、firefox以及其它浏览器对于table标签的操作都各不相同,在ie中不允许对table和tr的innerHTML赋值,使用js增加一个tr时,使用appendChild方法也不管用。

解决方法:

//向table追加一个空行:

varrow=otable.insertRow(-1);

varcell=document.createElement(”td”);

cell.innerHTML=“”;

cell.className=“XXXX”;

row.appendChild(cell);

[注]由于俺很少使用JS直接操作表格,这个问题没有遇见过。

建议使用JS框架集来操作table,如JQuery。

ul和ol列表缩进问题

消除ul、ol等列表的缩进时,样式应写成:

list-style:

none;margin:

0px;padding:

0px;

其中margin属性对IE有效,padding属性对FireFox有效。

←此句表述有误,详细见↓

[注]这个问题尚未实际验证,待验证后再来修改。

[注]

经验证,在IE中,设置margin:

0px可以去除列表的上下左右缩进、空白以及列表编号或圆点,设置padding对样式没有影响;在Firefox

中,设置margin:

0px仅仅可以去除上下的空白,设置padding:

0px后仅仅可以去掉左右缩进,还必须设置list-style:

none才

能去除列表编号或圆点。

也就是说,在IE中仅仅设置margin:

0px即可达到最终效果,而在Firefox中必须同时设置margin:

0px、

padding:

0px以及list-style:

none三项才能达到最终效果。

CSS透明问题

IE:

filter:

progid:

DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。

FF:

opacity:

0.6。

[注]最好两个都写,并将opacity属性放在下面。

CSS圆角问题

IE:

ie7以下版本不支持圆角。

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;。

[注]圆角问题是CSS中的经典问题,建议使用JQuery框架集来设置圆角,让这些复杂的问题留给别人去想吧。

二、IE6/IE7和Firefox对Div处理的差异

基本HTML代码

DOCTYPEhtmlPUBLIC“-//W3C//DTDXHTML1.0Transitional//EN”

“http:

//www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd”>

//www.w3.org/1999/xhtml”>

DivFloatSample

div{margin:

3px;}

.d1{width:

250px;min-height:

20px;border:

1pxsolid#00cc00;}

.d2{width:

130px;min-height:

40px;border:

1pxsolid#0000cc;}

.d3{width:

100px;min-height:

40px;border:

1pxsolid#cc0000;}

以上代码显示的结果如下,很正常,结果相同。

当然所有这些情况也许是有合理解释的,说不定增加某一个style的设置。

 

下面会在这个基础上进行修改,修改的内容都在style中,其他代码就不再重复写了。

请注意,这里的Style中用到了min-height,这个和height是不同的,min-height指定了对象的一个最小高度,当对象的子

内容高度超过这个最小高度是,这个对象会自动撑大。

这是一个非常牛的style,可惜的是,在这个style和float这个同样牛的style一起使用

的时候,就会出现各种问题。

内部一个Div修改成为float:

left

.d1{width:

250px;min-height:

20px;border:

1pxsolid#00cc00;}

.d2{width:

130px;min-height:

40px;border:

1pxsolid#0000cc;float:

left;}

.d3{width:

100px;min-height:

40px;border:

1pxsolid#cc0000;}

显示结果如下。

显示结果如下,显示结果如下!

 

显示结果如下。

:

left的情况相同?

这个结果中,Firefox有点离谱了,两个框叠在一起也就罢了,为什么那个红框会变大捏?

而且变的大小也很诡异,不知道是按照什么公式计算出来的。

IE在这里的显示应当是附和标准的。

内部两个Div都修改成为float:

left

.d1{width:

250px;min-height:

20px;border:

1pxsolid#00cc00;}

.d2{width:

130px;min-height:

40px;border:

1pxsolid#0000cc;float:

left;}

.d3{width:

100px;min-height:

40px;border:

1pxsolid#cc0000;float:

left;}

这和前面第一种加float:

left的情况相同。

显示结果如下。

 

在这种情况下,Firefox的结果尚能解释,可能是float把外层的Div也作为内层float影响的范围,这样内层的就不会将外层的Div撑大了。

IE在这里出现了Margin失效的情况,可以解释为内层第二个float造成了影响。

干脆把外层的Div也修改成为float:

left

.d1{width:

250px;min-height:

20px;border:

1pxsolid#00cc00;float:

left;}

.d2{width:

130px;min-height:

40px;border:

1pxsolid#0000cc;float:

left;}

.d3{width:

100px;min-height:

40px;border:

1pxsolid#cc0000;float:

left;}

以上代码在下面这些Doctype下试验过,结果相同。

显示结果如下,

 

这种情况下,Firefox正常了,而IE延续了前面的不正常情况。

外层是float:

left,内层最后一个不再float:

left

.d1{width:

250px;min-height:

20px;border:

1pxsolid#00cc00;float:

left;}

.d2{width:

130px;min-height:

40px;border:

1pxsolid#0000cc;float:

left;}

.d3{width:

100px;min-height:

40px;border:

1pxsolid#cc0000;}

left的情况相同。

所以最好是padding和margin都不用?

显示结果如下,

IE在这里的显示应当是附和标准的。

 

这和前面第一种加float:

left的情况相同。

结论

再重申一次,本文讨论的是一个比较高级的话题。

如果在style中用height而不是min-height来设定高度,是不会出现以上这些问题的。

不过,不用min-height就失去了div自动撑大这一个很有必要的特性。

在min-height和float:

left的情况下,没有一种完美的写法让Firefox和IE结果相同。

不过仍然可以发现绕开的方法。

进一步试验可以发现,margin遭到的影响在padding上比较好,所以最好是padding和margin都不用,或者只用padding。

两者相同的代码如下,

div{padding:

3px;}

.d1{width:

250px;min-height:

20px;border:

1pxsolid#00cc00;float:

left;}

.d2{width:

130px;min-height:

40px;border:

1pxsolid#0000cc;float:

left;}

.d3{width:

100px;min-height:

40px;border:

1pxsolid#cc0000;float:

left;}

left的情况相同。

当对象的子内容高度超过这个最小高度是。

显示结果如下,

 

呵呵,总算是一样了,虽然是凑合着一样了。

幸好一样了,否则只好用table了。

当然所有这些情况也许是有合理解释的,说不定增加某一个style的设置,这些问题都迎刃而解了,不过目前我还没有找到这个设置。

关于Doctype

可惜的是,在这个style和float这个同样牛的style一起使用的时候。

以上代码在下面这些Doctype下试验过,结果相同。

DOCTYPEhtmlPUBLIC“-//W3C//DTDHTML4.01//EN”

“http:

//www.w3.org/TR/html4/strict.dtd“>

DOCTYPEhtmlPUBLIC“-//W3C//DTDHTML4.01Transitional//EN”

“http:

//www.w3.org/TR/html4/loose.d

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 表格模板 > 合同协议

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2