<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
<script language="javascript">
function GetAllId(nRootId,e){
var evt=window.event||e;
var srcEl=evt.srcElement||evt.target;
var strOut="";
var obj=srcEl;
while(obj.id){
strOut+=obj.id;
if(obj.id==nRootId)
break;
//消除tbody的影响
if(obj.parentNode.tagName!="TBODY")
obj=obj.parentNode;
else
obj=obj.parentNode.parentNode;
}
alert(strOut);
}
</script>
</head>
<body>
<div id="1"><table id="2"><tr id="3"><td id="4"><span id="5" onclick="GetAllId(1,event)">test</span></td></tr></table></div></div>
</body>
</html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
<script language="javascript">
function GetAllId(nRootId,e){
var evt=window.event||e;
var srcEl=evt.srcElement||evt.target;
var strOut="";
var obj=srcEl;
while(obj.id){
strOut+=obj.id;
if(obj.id==nRootId)
break;
//消除tbody的影响
if(obj.parentNode.tagName!="TBODY")
obj=obj.parentNode;
else
obj=obj.parentNode.parentNode;
}
alert(strOut);
}
</script>
</head>
<body>
<div id="1"><table id="2"><tr id="3"><td id="4"><span id="5" onclick="GetAllId(1,event)">test</span></td></tr></table></div></div>
</body>
</html>
的运行ie下也可以用parnetElement
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
<script language="javascript">
function GetAllId(nRootId,e){
var evt=window.event||e;
var srcEl=evt.srcElement||evt.target;
var strOut="";
var obj=srcEl;
while(obj.id){//最上层对象为document防止无限循环
strOut+=obj.id;
if(obj.id==nRootId)
break;
//消除tbody的影响
if(obj.parentNode.tagName!="TBODY")
obj=obj.parentNode;
else{
if(obj.id)
obj=obj.parentNode;
else
obj=obj.parentNode.parentNode;
}
}
alert(strOut);
}
</script>
</head>
<body>
<div id="1"><table id="2"><tr id="3"><td id="4"><span id="5" onclick="GetAllId(1,event)">test</span></td></tr></table></div></div>
</body>
</html>
{
var arr = [];
while(obj && obj.tagName && obj.tagName.toLowerCase()!="body")
{
if(obj.id)arr[arr.length] = obj.id;
obj = obj.parentNode;
}
return arr;
}
onclick="alert(getParentId(this));"
{
var arr = [];
while(obj && obj.tagName.toLowerCase()!="body")
{
if(obj.id)arr[arr.length] = obj.id;
obj = obj.parentNode;
}
return arr;
}....
onclick="alert(getParentId(this));"
<head>
<script type="text/javascript">
var strid;
function Test(obj)
{
strid=obj.id;
Test2(obj.parentNode)
alert(strid);
}
function Test2(parentObj)
{
if(parentObj.id)
{
strid+=","+parentObj.id;
Test2(parentObj.parentNode)
}
else if(parentObj.tagName=="TBODY")
{
Test2(parentObj.parentNode)
}
}
</script>
</head>
<body>
<div id="1"><table id="2"><tr id="3"><td id="4"><span id="5" onclick="Test(this)">test</span></td></tr></table></div>
</body>
</html>