兼容IE和FireFox浏览器的get event事件写法

时间:13-10-22 栏目:网站开发 作者:admin 评论:0 点击: 3,570 次

<script>
function getEvent()  
{  
if(!(document.getElementById&& (navigator.appName=="Netscape")))  return window.event;    
func=getEvent.caller;        
while(func!=null){  
    var arg0=func.arguments[0];
    if(arg0)
    {
        if((arg0.constructor==Event || arg0.constructor ==MouseEvent) || (typeof(arg0)=="object" && arg0.preventDefault && arg0.stopPropagation))
        {
            return arg0;
        }
    }
    func=func.caller;
} 
return null; 
}
//测试函数,打印所有event支持的属性,包括 clientX、target、srcElement等
function test(){
	var evt = getEvent();
	//(evt.srcElement || evt.target);
	var html = '<ul>';
	var text = '';
	for(var i in evt){
		try{
			if(typeof(evt[i]) == 'object' && (i=='srcElement'||i=='target')){
				html +='<li style="color:green">'+ i+':<ul>';
				text +=''+i+':';
				for(var ii in evt[i]){
					try{
						html +='<li>'+ ii+':'+evt[i][ii].toString()+'</li>';
						text +='	'+ii+':'+evt[i][ii].toString()+"\r\n";;
					}catch(E){
						html +='<li>'+ii+':'+E.toString()+'</li>';
						text +='	'+ii+':'+E.toString()+"\r\n";
					}
				}
				html +='</ul></li>';
			}else

			html +='<li>'+ i+':'+evt[i]+'</li>';
			text +=''+i+':'+evt[i]+"\r\n";;
		}catch(E){
			html +='<li>'+i+':'+E.toString()+'</li>';
			text +=''+i+':'+E.toString()+"\r\n";
		}
	}
	html += '</ul>';
	document.getElementById('D1').innerHTML = html;
	if(document.getElementById('D2').innerText)
	document.getElementById('D2').innerText = text;
	else document.getElementById('D2').innerHTML = text;

}

/**/
</script>

<div>
<table width="100%">
<tr>
  <td>testCode
</td><td><input id="testID" value="Click Me!" type="button" onClick="test()">
</td>
</tr>
<tr>

  <td width="50%" valign="top"><textarea style="width:100%" rows="30" id="D2">TEST</textarea></td>
  <td width="50%"><div  id="D1" style="overflow:auto; height:450px"></div></td>
  </tr>
</table>
</div>

声明: 本文由( admin )原创编译,转载请保留链接: 兼容IE和FireFox浏览器的get event事件写法

兼容IE和FireFox浏览器的get event事件写法:等您坐沙发呢!

发表评论


------====== 本站公告 ======------
联系信息:
lxq73061#qq.com qq:583964941
支付宝:https://me.alipay.com/lxq73061
相关插件程序等信息均会在站内发布,敬请关注。

读者排行