文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档>firefox、IE下的几个不同属性的方法调用

firefox、IE下的几个不同属性的方法调用

时间:2010-10-03  来源:与时俱进

声明:document.all:该对象只有IE中才存在,故用该对象来判断浏览器的类型

一、IFRAME的对象

在IE下可通过document.frames["id"];得到该IFRAME对象,

而在火狐下则是通过document.getElementById("content_panel_if").contentWindow;

代码如下:

 
  1. if(!document.all){  //火狐中得到IFRAME的对象   
  2.     _Frame=document.getElementById("id").contentWindow;   
  3. }else{   
  4.      _Frame=document.frames["id"];
  5. }  
if(!document.all){  //火狐中得到IFRAME的对象       _Frame=document.getElementById("id").contentWindow;   }else{        _Frame=document.frames["id"];}  

二、得到对象的第一个子元素

 IE的写法: _tbody=_table.childNodes[0]

在FF中,firefox会在子节点中包含空白则第一个子节点为空白"#text", 而ie不会返回空白

可以通过if("#text" != node.nodeName)过滤掉空白子对象

 

三、添加背景图片

 
  1. if(!document.all){   
  2.        var _tempSrc="xx\xx\xx.gif";   
  3.        _tempSrc=_tempSrc.replace(/\\/g,"/");  //全部替换   
  4.      markerDiv.style.backgroundImage="url("+_tempSrc+")";   
  5. }else{   
  6.         markerDiv.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src=" + this.icon.src    
  7. + ", sizingmethod=scale);";  //火狐不支持这种写法   
  8. }  
if(!document.all){          var _tempSrc="xx\xx\xx.gif";          _tempSrc=_tempSrc.replace(/\\/g,"/");  //全部替换        markerDiv.style.backgroundImage="url("+_tempSrc+")";   }else{           markerDiv.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src=" + this.icon.src    + ", sizingmethod=scale);";  //火狐不支持这种写法   }  

四、模拟CLIKC事件

如该实例:

 
  1. <a href="#" onclick="test(1)" id="a3">hello</a>
  2. <a href="#" onclick="test2(1)" id="b3">hello2</a>
  3. <script language="javascript">  
  4. <!--  
  5. function test(num){  
  6.     window.alert(num);  
  7. }  
  8. function test2(num)  
  9. {  
  10.     if(document.all){  //ie下 
  11.         document.getElementById("a3").click();  
  12.     }
  13.     else{  
  14.         var evt = document.createEvent("MouseEvents");  
  15.         evt.initEvent("click", true, true);  
  16.         document.getElementById("a3").dispatchEvent(evt);  
  17.     }  
  18. }  
  19. //-->  
  20. </script>
<a href="#" onclick="test(1)" id="a3">hello</a><a href="#" onclick="test2(1)" id="b3">hello2</a><script language="javascript">  <!--  function test(num){      window.alert(num);  }  function test2(num)  {   if(document.all){  //ie下                document.getElementById("a3").click();          }       else{           var evt = document.createEvent("MouseEvents");                  evt.initEvent("click", true, true);             document.getElementById("a3").dispatchEvent(evt);       }  }  //-->  </script>


 event.initEvent(eventType,canBubble,cancelable) :

 initEvent 该方法将初始化 Document.createEvent() 方法创建的合成 Event 对象的 type 
 属性、bubbles 属性和 cancelable 属性。 只有在新创建的 Event 对象被 Document 对象或 Element 
对象的 dispatchEvent() 方法分派之前,才能调用 Event.initEvent() 方法。

 

五、attachEvent函数

if (isIE){window.attachEvent("onload", init);}else{window.addEventListener("load", init, false);}

排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载