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

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

IE语法:

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

Firefox语法:

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

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);
  3. }

Firefox语法:

 
 
 
  1. #myElement {
  2. opacity: 0.5;
  3. }

要使用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,来创建动画效果,但这这是个简单的例子,只是为了明白地描述方法是如何实现地。

网站标题:Firefox和IE之间7个JavaScript差异
标题来源:http://www.shufengxianlan.com/qtweb/news41/9791.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联