<!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>

解决方案 »

  1.   

    说白了,就是parentNode
    的运行ie下也可以用parnetElement
      

  2.   

    这样可能会更好些因为用户有时会写tbody<!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){//最上层对象为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>
      

  3.   

    function getParentId(obj)
    {
        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));"
      

  4.   

    function getParentId(obj)
    {
        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));"
      

  5.   

    <html>
    <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>
      

  6.   

    循环parentNode.id,直到div