您的位置:首页 > Web前端 > JavaScript

js中浏览器的兼容问题

2011-11-16 09:57 441 查看
ocument.getElementById("mybutton").style.display="";可见,mybutton为控件id;

document.getElementById("mybutton").style.display="none";不可见

今天还碰到多表查询的问题,在多表查询中我们可以把只要不是同样字段名得列直接列出,而不用加前缀数据库名。还有一个需要注意的地方,就是在mysql中不要使用()括号把字段名和数据库括起来。这是不知道为何,单表没问题

js和css的属性规律:

background background

background-attachment backgroundAttachment

background-color backgroundColor

background-image backgroundImage

这个是有规律的,CSS属性中如果是一个单词的,在JS中也是同样的,如果CSS属性中带连接符的,在JS中调用时,就把连接符去掉,连接符后面的单词第一个字母大写!

用JS 设置 控件 属性

//设置控件被选中

document.getElementById("id").checked=true;

//设置控件不可用

document.getElementById("id").disabled = true;

//设置控件不可见

document.getElementById("id").style.display='none';

//设置控件可见

document.getElementById("id").style.display='block';

//设置控件获取焦点

document.getElementById("id").focus();

Internet Explorer(IE)与Firefox(FF)中不同的Javascript2011-08-01 10:39:06 我来说两句 收藏 我要投稿 [字体:小 大]

最近快要被DIV+CSS的兼容性问题折腾疯了,真受不了各大浏览器搞的什么标准?害得咱们小小的web程序员跟着这些浏览器的“烂问题”滴溜溜的转

原文如下,自己看吧,我已经晕了:

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

1.document.formName.item("itemName") 问题

  问题说明:IE下,可以使用document.formName.item("itemName") 或document.formName.elements ["elementName"];Firefox下,只能使用document.formName.elements["elementName"]。

  解决方法:统一使用document.formName.elements["elementName"]。

  2.集合类对象问题

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

  解决方法:统一使用[] 获取集合类对象。

  3.自定义属性问题

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

  解决方法:统一通过getAttribute() 获取自定义属性。

  4.eval("idName")问题

  问题说明:IE下,可以使用eval("idName") 或getElementById("idName") 来取得id 为idName 的HTML对象;Firefox下,只能使用getElementById("idName") 来取得id 为idName 的HTML对象。

  解决方法:统一用getElementById("idName") 来取得id 为idName 的HTML对象。

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

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

  解决方法:使用document.getElementById("idName") 代替document.idName。最好不要取HTML对象ID相同的变量名,以减少错误;在声明变量时,一律加上var关键字,以避免歧义。

  6.const问题

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

  解决方法:统一使用var关键字来定义常量。

  7.input.type属性问题

  问题说明:IE下input.type 属性为只读;但是Firefox下input.type 属性为读写。

解决办法:不修改input.type 属性。如果必须要修改,可以先隐藏原来的input,然后在同样的位置再插入一个新的input元素。

  8.window.event问题

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

  解决方法:在事件发生的函数上加上event参数,在函数体内(假设形参为evt)使用var myEvent = evt?evt:(window.event?window.event:null)

示例:<input type="button" onclick="doSomething(event)"/>

  <script language="javascript">

  function doSomething(evt) {

  var myEvent = evt?evt:(window.event?window.event:null)

  ...

  }

9.event.x与event.y问题

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

  解决方法:var myX = event.x ? event.x : event.pageX; var myY = event.y ? event.y:event.pageY;

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

  10.event.srcElement问题

  问题说明:IE下,even对象有srcElement属性,但是没有target属性;Firefox下,even对象有target属性,但是没有srcElement属性。

  解决方法:使用srcObj = event.srcElement ? event.srcElement : event.target;

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

  11.window.location.href问题

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

  解决方法:使用window.location 来代替window.location.href。当然也可以考虑使用location.replace()方法。

  12.模态和非模态窗口问题

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

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

如果需要将子窗口中的参数传递回父窗口,可以在子窗口中使用window.opener来访问父窗口。如果需要父窗口控制子窗口的话,使用var subWindow = window.open(pageURL,name,parameters); 来获得新开的窗口对象。

  13.frame和iframe问题

  以下面的frame为例:

  <frame src="xxx.html" id="frameId" name="frameName" />

  (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关键字来访问父窗口。

  14.body载入问题

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

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

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

  15. 事件委托方法

  问题说明:IE下,使用document.body.onload = inject; 其中function inject()在这之前已被实现;在Firefox下,使用document.body.onload = inject();

  解决方法:统一使用document.body.onload=new Function('inject()'); 或者document.body.onload = function(){/* 这里是代码*/}

[注意] Function和function的区别

  16.访问的父元素的区别

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

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

  17.cursor:hand VS cursor:pointer

  问题说明:firefox不支持hand,但ie支持pointer ,两者都是手形指示。

  解决方法:统一使用pointer。

  18.innerText的问题.

问题说明:innerText在IE中能正常工作,但是innerText在FireFox中却不行。

解决方法:在非IE浏览器中使用textContent代替innerText。

示例:

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

  document.getElementById('element').innerText = "my text";

  } else{

  document.getElementById('element').textContent = "my text";

  }

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

  19. 对象宽高赋值问题

  问题说明:FireFox中类似obj.style.height = imgObj.height 的语句无效。

解决方法:统一使用obj.style.height = imgObj.height + 'px';

  20. Table操作问题

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

  解决方法:

  //向table追加一个空行:

  var row = otable.insertRow(-1);

  var cell = document.createElement("td");

  cell.innerHTML = "";

  cell.className = "XXXX";

  row.appendChild(cell);

[注] 由于俺很少使用JS直接操作表格,这个问题没有遇见过。建议使用JS框架集来操作table,如JQuery。

  21. 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三项才能达到最终效果。

  22. CSS透明问题

  IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。

  FF:opacity:0.6。

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

  23. 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框架集来设置圆角,让这些复杂的问题留给别人去想吧。

  关于CSS中的问题实在太多了,甚至同样的CSS定义在不同的页面标准中的显示效果都是不一样的。一个合乎发展的建议是,页面采用标准DHTML标准编写,较少使用table,CSS定义尽量依照标准DOM,同时兼顾IE、Firefox、Opera等主流浏览器。BTW,很多情况下,FF和Opera的CSS解释标准更贴近CSS标准,也更具有规范性

本文来源:关涛的博客http://www.hnzyb.com/

原文链接:http://www.hnzyb.com/blog/?id=1451

1. document.form.item 问题

(1)现有问题:

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

(2)解决方法:

改用document.formName.elements["elementName"]

(3)其它

参见2

2. 集合类对象问题

(1)现有问题:

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

(2)解决方法:

改用[] 作为下标运算。如:document.forms("formName") 改为document.forms["formName"]。

又如:document.getElementsByName("inputName")(1) 改为document.getElementsByName("inputName")[1]

(3)其它

3. window.event

(1)现有问题:

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

(2)解决方法:

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

原 代码(可在IE中运行):<br /><input type="button" name="someButton" value="提交" onclick="javascript:gotoSubmit()"/><br />...<br /><script language="javascript"><br />function gotoSubmit() {<br />...<br />alert(window.event); // use window.event<br />...<br />}<br /></script>

新 代码(可在IE和火狐中运行):<input type="button" name="someButton" value="提交" onclick="javascript:gotoSubmit(event)"/><br />...<br /><script language="javascript"><br />function gotoSubmit(evt) {<br />evt = evt ? evt : (window.event ? window.event : null);<br />...<br
/>alert(evt); // use evt<br />...<br />}<br /></script>

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

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

(1)现有问题

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

(2)解决方法

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

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

(1)现有问题

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

(2)解决方法

用getElementById(idName) 代替eval(idName)。

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

(1)现有问题

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

(2)解决方法

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

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

(3)其它

参见 问题4

7. event.x 与event.y 问题

(1)现有问题

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

(2)解决方法

在火狐中,与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与火狐中都有,具体意义有无差别尚未试验。

8. 关于frame

(1)现有问题

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

(2)解决方法

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

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

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

那么ie可以通过id或者name访问这个frame对应的window对象

而火狐只可以通过name来访问这个frame对应的window对象

例如如果上述frame标签写在最上层的window里面的htm里面,那么可以这样访问

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.htm'来切换frame的内容

也都可以通过window.top.frameName.location = 'xx.htm'来切换frame的内容

关于frame和window的描述可以参见bbs的‘window与frame’文章

以及/test/js/test_frame/目录下面的测试

----adun 2004.12.09修改

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

10.在火狐中没有parentElement parement.children 而用

parentNode parentNode.childNodes

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

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

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

<form>

<table>

<input/>

</table>

</form>

火狐中input.parentNode的值为form, 而IE中input.parentNode的值为空节点

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

11.const 问题

(1)现有问题:

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

(2)解决方法:

不使用const ,以var 代替。

12. body 对象

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

13. url encoding

在js中如果书写url就直接写&不要写&例如var url = 'xx.jsp?objectName=xx&objectEvent=xxx';

frm.action = url那么很有可能url不会被正常显示以至于参数没有正确的传到服务器

一般会服务器报错参数没有找到

当然如果是在tpl中例外,因为tpl中符合xml规范,要求&书写为&

一般火狐无法识别js中的&

14. nodeName 和tagName 问题

(1)现有问题:

在火狐中,所有节点均有nodeName 值,但textNode 没有tagName 值。在IE 中,nodeName 的使用好象

有问题(具体情况没有测试,但我的IE已经死了好几次)。

(2)解决方法:

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

15. 元素属性

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

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

(1)现有问题:

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

摘:http://firefox.sun-sky.com.cn/post/javascript.html

1.兼容firefox的outerHTML,FF中没有outerHtml的方法。

if (window.HTMLElement) {

HTMLElement.prototype.__defineSetter__("outerHTML",function(sHTML) {

var r=this.ownerDocument.createRange();

r.setStartBefore(this);

var df=r.createContextualFragment(sHTML);

this.parentNode.replaceChild(df,this);

return sHTML;

});

HTMLElement.prototype.__defineGetter__("outerHTML",function() {

var attr;

var attrs=this.attributes;

var str="<"+this.tagName.toLowerCase();

for (var i=0;i<attrs.length;i++) {

attr=attrs;

if(attr.specified)

str+=" "+attr.name+'="'+attr.value+'"';

}

if(!this.canHaveChildren)

return str+">";

return str+">"+this.innerHTML+"</"+this.tagName.toLowerCase()+">";

});

HTMLElement.prototype.__defineGetter__("canHaveChildren",function() {

switch(this.tagName.toLowerCase()) {

case "area":

case "base":

case "basefont":

case "col":

case "frame":

case "hr":

case "img":

case "br":

case "input":

case "isindex":

case "link":

case "meta":

case "param":

return false;

}

return true;

});

}

3.自定义属性问题

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

解决方法:统一通过getAttribute()获取自定义属性.

4.eval("idName")问题

说明:IE下,,可以使用eval("idName")或getElementById("idName")来取得id为idName的HTML对象;Firefox下只能使用getElementById("idName")来取得id为idName的HTML对象.

解决方法:统一用getElementById("idName")来取得id为idName的HTML对象.

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

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

解决方法:使用document.getElementById("idName")代替document.idName.最好不要取HTML对象ID相同的变量名,以减少错误;在声明变量时,一律加上var,以避免歧义.

6.const问题

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

解决方法:统一使用var关键字来定义常量.

7.input.type属性问题

说明:IE下input.type属性为只读;但是Firefox下input.type属性为读写.

8.window.event问题

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

解决方法:

IE:

<input name="Button8_1" type="button" value="IE" onclick="javascript:gotoSubmit8_1()"/>

...

<script language="javascript">

function gotoSubmit8_1() {

...

alert(window.event); //use window.event

...

}

</script>

IE&Firefox:

<input name="Button8_2" type="button" value="IE" onclick="javascript:gotoSubmit8_2(event)"/>

...

<script language="javascript">

function gotoSubmit8_2(evt) {

...

evt=evt?evt:(window.event?window.event:null);

alert(evt); //use evt

...

}

</script>

9.event.x与event.y问题

说明:IE下,even对象有x,y属性,但是没有pageX,pageY属性;Firefox下,even对象有pageX,pageY属性,但是没有x,y属性.

解决方法:使用mX(mX = event.x ? event.x : event.pageX;)来代替IE下的event.x或者Firefox下的event.pageX.

10.event.srcElement问题

说明:IE下,even对象有srcElement属性,但是没有target属性;Firefox下,even对象有target属性,但是没有srcElement属性.

解决方法:使用obj(obj = event.srcElement ? event.srcElement : event.target;)来代替IE下的event.srcElement或者Firefox下的event.target.

11.window.location.href问题

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

解决方法:使用window.location来代替window.location.href.

12.模态和非模态窗口问题

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

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

如 果需要将子窗口中的参数传递回父窗口,可以在子窗口中使用window.opener来访问父窗口. 例如:var parWin = window.opener; parWin.document.getElementById("Aqing").value = "Aqing";

13.frame问题

以下面的frame为例:

<frame src="xxx.html" id="frameId" name="frameName" />

(1)访问frame对象:

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

Firefox:只能使用window.frameName来访问这个frame对象.

另外,在IE和Firefox中都可以使用window.document.getElementById("frameId")来访问这个frame对象.

(2)切换frame内容:

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

如果需要将frame中的参数传回父窗口,可以在frme中使用parent来访问父窗口。例如:parent.document.form1.filename.value="Aqing";

14.body问题

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

例如:

Firefox:

<body >

<script type="text/javascript">

document.body.onclick = function(evt){

evt = evt || window.event;

alert(evt);

}

</script>

</body>

IE&Firefox:

<body >

</body>

<script type="text/javascript">

document.body.onclick = function(evt){

evt = evt || window.event;

alert(evt);

} </script>

15. 事件委托方法

IE:document.body.onload = inject; //Function inject()在这之前已被实现

Firefox:document.body.onload = inject();

有人说标准是:

document.body.onload=new Function('inject()');

16. firefox与IE(parentElement)的父元素的区别

IE:obj.parentElement

firefox:obj.parentNode

解决方法: 因为firefox与IE都支持DOM,因此使用obj.parentNode是不错选择.

17.cursor:hand VS cursor:pointer

firefox不支持hand,但ie支持pointer

解决方法: 统一使用pointer

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

解决方法:

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

document.getElementById('element').innerText = "my text";

} else{

document.getElementById('element').textContent = "my text";

}

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

解决方法:

obj.style.height = imgObj.height + 'px';

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

解决方法:

//向table追加一个空行:

var row = otable.insertRow(-1);

var cell = document.createElement("td");

cell.innerHTML = " ";

cell.className = "XXXX";

row.appendChild(cell);

21. padding 问题

padding 5px 4px 3px 1px FireFox无法解释简写,

必须改成padding-top:5px; padding-right:4px; padding-bottom:3px; padding-left:1px;

22. 消除ul、ol等列表的缩进时

样式应写成:list-style:none;margin:0px;padding:0px;

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

23. CSS透明

IE:filter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60)。

FF:opacity:0.6。

24. CSS圆角

IE:不支持圆角。

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

25. CSS双线凹凸边框

IE:border:2px outset;。

FF:-moz-border-top-colors: #d4d0c8 white;-moz-border-left-colors: #d4d0c8 white;-moz-border-right-colors:#404040 #808080;-moz-border-bottom-colors:#404040 #808080;

IE有3种方式都可以创建一个元素:

1 document.createElement("<input type=text>")

2 document.createElement("<input>")

3 document.createElement("input")

Firefox只支持一种方式:

document.createElement("input");document.setAttribute(name,value);

------------

注: 在一个节点下增加子节点IE也比Firefox下的方式要多.

IE:

1 node.insertBefore(Element)

2 node.insertAfter(Element)

3 node.appendChild(Element)

而Firefox仅支持node.appendChild.

在IE里面,html元素如果可以作为容器,那么在document.createElement创建元素时是无法设置name属性的,比如:div,span,font等等。

相反不可以做为容器的,在用document.createElement创建元素时可以设置控件的name属性,比如:input,button,a,img等等
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: