Firefox和IE之间7个JavaScript差异

尽管JavaScript历史上使用冗长而令人生厌的代码块来标的特定浏览器的时期已经结束了,但是偶尔使用一些简单的代码块和对象检测来确保一些代码在用户机器上正常工作依然是必要的。

推荐阅读:JavaScript在IE和FireFox中的不同表现

1. CSS“float”属性

获取给定对象的特定CSS属性的基本语法是object.style属性,而且有连字符的属性要用骆驼命名法来代替。例如,获取一个ID为 “header”的div的background-color属性,我们要用如下语法:

 
 
 
  1. document.getElementById("header").style.borderBottom"1px solid #ccc"
  2.  

但是由于“float”是 JavaScript 的保留词,我们就无法使用 object.style.float 来获取“float”属性了。一下是我们在两种浏览器中的使用的方法:

IE语法:

 
 
 
  1. document.getElementById("header").style.styleFloat = "left";
  2.  

Firefox语法:

 
 
 
  1. document.getElementById("header").style.cssFloat = "left"
  2.  

2. 元素的计算样式

通过使用上述的object.style.property, JavaScript可以很容易的获取和修改对象的设定CSS样式。但是这一语法的局限在于,它只能取得内联在HTML里的样式,或者直接使用JavaScript设定的样式。style对象不能获取使用外部样式表设定的样式。为了获取对象的”计算样式”,我们使用以下代码:

IE语法:

 
 
 
  1. var myObject = document.getElementById("header");  
  2. var myStyle = myObject.currentStyle.backgroundColor; 

Firefox语法:

 
 
 
  1. var myObject = document.getElementById("header");  
  2. var myComputedStyle = document.defaultView.getComputedStyle(myObject, null);  
  3. var myStyle = myComputedStyle.backgroundColor; 

3. 获取元素的”class”属性

类似于”float”属性的情况,这两种浏览器使用不同的JavaScript方法来获取这个属性。

IE语法:

 
 
 
  1. var myObject = document.getElementById("header");  
  2. var myAttribute = myObject.getAttribute("className"); 

Firefox语法:

 
 
 
  1. var myObject = document.getElementById("header");  
  2. var myAttribute = myObject.getAttribute("class"); 

4. 获取label标签的 “for” 属性

和第三个问题一样,使用JavaScript获取label的“for”属性也有不同语法。

IE语法:

 
 
 
  1. var myObject = document.getElementById("myLabel");  
  2. var myAttribute = myObject.getAttribute("htmlFor"); 

Firefox语法:

 
 
 
  1. var myObject = document.getElementById("myLabel");  
  2. var myAttribute = myObject.getAttribute("for"); 

对于setAtrribute方法来说也是同样的语法。

5. 获取光标位置

获取元素的光标位置比较少见,如果需要这么做,IE和Firefox的语法也是不同的。这个示例代码是相当基础的,一般用作许多复杂事件处理的一部分,这里仅用来描述差异。需要注意的是,IE中的结果和Firefox中是不同的,因此这个方法有些问题。

IE语法:

 
 
 
  1. var myCursorPosition = [0, 0];  
  2. myCursorPosition[0] = event.clientX;  
  3. myCursorPosition[1] = event.clientY; 

Firefox语法:

 
 
 
  1. var myCursorPosition = [0, 0];  
  2. myCursorPosition[0] = event.pageX;  
  3. myCursorPosition[1] = event.pageY; 

6. 获取视窗或浏览器窗口的尺寸

有时需要找出浏览器的有效窗口空间的尺寸,一般成为”视窗”。

IE语法:

 
 
 
  1. var myBrowserSize = [0, 0];  
  2. myBrowserSize[0] = document.documentElement.clientWidth;  
  3. myBrowserSize[1] = document.documentElement.clientHeight; 

Firefox语法:

 
 
 
  1. var myBrowserSize = [0, 0];  
  2. myBrowserSize[0] = window.innerWidth;  
  3. myBrowserSize[1] = window.innerHeight; 

7. Alpha 透明

这其实不是JavaScript的语法项目 – alpha透明是通过CSS来设置的。但是当对象通过JavaScript设置为淡入淡出时,这就需要通过获取CSS的alpha设定来实现,一般是在循环内部。要通过以下JavaScript来改变CSS代码:

IE语法:

 
 
 
  1. #myElement {  
  2. filter: alpha(opacity=50);  

Firefox语法:

 
 
 
  1. #myElement {  
  2. opacity: 0.5;  

要使用JavaScript获取这些值,需要使用style对象:

IE语法:

 
 
 
  1. var myObject = document.getElementById("myElement");  
  2. myObject.style.filter = "alpha(opacity=80)"

Firefox语法:

 
 
 
  1. var myObject = document.getElementById("myElement");  
  2. myObject.style.opacity = "0.5"

当然,已经说到了,一般是在循环中间来改变opcity/alpha,来创建动画效果,但这这是个简单的例子,只是为了明白地描述方法是如何实现地。

【编辑推荐】

  1. IPTV会否是分众购对象
  2. 我国IPTV研究目全球领先
  3. 3G与IPTV是发展大方向
  4. 我国IPTV研究目全球领先
  5. 3G与IPTV是发展大方向
THE END