通过js动态创建table并调整tr顺序

翻译|其它|编辑:郝浩|2008-01-17 10:09:15.000|阅读 4794 次

概述:

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

Html代码
<HTML> 
    <HEAD> 
        <TITLE>TestTable</TITLE> 
        <script> 
            function submitTable()  
            {  
                var trArray = document.getElementsByName("nameTr");  
                if (trArray)  
                {  
                    for (var i = 0; i < trArray.length; i++)  
                    {  
                        var tr = trArray[i];  
                        var tdArray = tr.getElementsByTagName("td");  
                        var index = tdArray[0].innerHTML;  
                        var name = tdArray[1].innerHTML;  
                        alert(index + ": " + name);  
                    }  
                }  
            }  
 
            function addNameTR()  
            {  
                var userName = document.getElementById("nameText").value;  
                var table    = document.getElementById("tableBody");  
 
                var tr = document.createElement('tr');  
                tr.id = "nameTr";  
                table.appendChild(tr);  
 
                var td1 = document.createElement('td');  
                tr.appendChild(td1);  
                td1.appendChild(document.createTextNode(getNameTrIndex()));  
 
                var td2 = document.createElement('td');  
                tr.appendChild(td2);  
                td2.appendChild(document.createTextNode(userName));  
 
                var td3 = document.createElement('td');  
                tr.appendChild(td3);  
                var upHref = "<a href='javascript:void(0);' onclick=\"upTR(this);\">上移</a>";  
                var downHref = "<a href='javascript:void(0);' onclick=\"downTR(this);\">下移</a>";  
                var delHref = "<a href='javascript:void(0);' onclick=\"delTR(this);\">删除</a>";  
                td3.innerHTML = upHref + "  " + downHref + "  " + delHref;  
            }  
 
            function getNameTrIndex()  
            {  
                var table = document.getElementById("tableBody");  
                var trArray = document.getElementsByName("nameTr");  
                if (trArray) {  
                    return trArray.length;  
                }  
                else {  
                    return 1;  
                }  
            }  
 
            function upTR(link)  
            {  
                var table      = document.getElementById("tableBody");  
                var selectedTr = link.parentElement.parentElement;  
                var preTr      = selectedTr.previousSibling;  
                if (preTr && preTr.id != "topTr")  
                {  
                    var selectedIndex = selectedTr.getElementsByTagName("td")[0].innerHTML;  
                    selectedTr.getElementsByTagName("td")[0].innerHTML = preTr.getElementsByTagName("td")[0].innerHTML;  
                    preTr.getElementsByTagName("td")[0].innerHTML = selectedIndex;  
                    table.insertBefore(selectedTr, preTr);  
                }  
            }  
 
            function downTR(link)  
            {  
                var table      = document.getElementById("tableBody");  
                var selectedTr = link.parentElement.parentElement;  
                var nextTr     = selectedTr.nextSibling;  
                if (nextTr)  
                {  
                    var selectedIndex = selectedTr.getElementsByTagName("td")[0].innerHTML;  
                    selectedTr.getElementsByTagName("td")[0].innerHTML = nextTr.getElementsByTagName("td")[0].innerHTML;  
                    nextTr.getElementsByTagName("td")[0].innerHTML = selectedIndex;  
                    table.insertBefore(nextTr, selectedTr);  
                }  
            }  
 
            function delTR(link)  
            {  
                if (window.confirm("确认删除?"))  
                {  
                    var table = document.getElementById("tableBody");  
                    var selectedTr = link.parentElement.parentElement;  
                    while(selectedTr.nextSibling)  
                    {  
                        selectedTrselectedTr = selectedTr.nextSibling;  
                        selectedTr.getElementsByTagName("td")[0].innerHTML -= 1;  
                    }  
                    table.removeChild(link.parentElement.parentElement);  
                }  
            }  
        </script> 
    </HEAD> 
 
    <BODY> 
        <table border="1" bordercolor='#000000' align="center" style="border-collapse:collapse;width:500px"> 
            <tbody id="tableBody"> 
                <tr id="topTr"> 
                    <td width="200px"> 
                        <input type="text" name="nameText"> 
                    </td> 
                    <td width="150px"><input type="button" value="Add" onclick="addNameTR()"></td> 
                    <td width="150px"><input type="button" value="Submit" onclick="submitTable();"></td> 
                </tr> 
            </tbody> 
        </table> 
    </BODY> 
</HTML> 


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:个人博客

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP