> 웹 프론트엔드 > HTML 튜토리얼 > HTML에 테이블을 동적으로 추가하는 방법에 대한 분석 예

HTML에 테이블을 동적으로 추가하는 방법에 대한 분석 예

黄舟
풀어 주다: 2018-05-11 17:11:41
원래의
6242명이 탐색했습니다.

이 글에서는 주로 HTML에서 테이블을 동적으로 추가하는 예제 코드를 소개합니다. 필요하신 분들은 참고하시면 됩니다

더 이상 헛소리하지 마세요. 구체적인 코드는 다음과 같습니다.

<html>  
    <head><title>Table</title></head>  
    <body>  
        <table border="1">  
            <thead>  
                <tr>  
                    <td>First Name</td>  
                    <td>Last Name</td>  
                    <td> </td>  
                </tr>  
            <thead>  
            <tbody id="tb">  
                <tr id="1st">  
                    <td>张</td>  
                    <td>三</td>  
                    <td><input type="button" value="Add" onclick="add()">   
                    <input type="button" value="Del" onclick="del(this)"></td>  
                </tr>  
            </tbody>  
        </table>  
    </body>  
</html>  
<script>  
    function add() {  
        var trObj = document.createElement("tr");  
        trObj.id = new Date().getTime();  
        trObj.innerHTML = "<td><input name=&#39;firstName&#39;/></td><td><input name=&#39;lastName&#39;/></td><td><input type=&#39;button&#39; value=&#39;Add&#39; onclick=&#39;add()&#39;> <input type=&#39;button&#39; value=&#39;Del&#39; onclick=&#39;del(this)&#39;></td>";  
        document.getElementById("tb").appendChild(trObj);  
    }  
    function del(obj) {  
        var trId = obj.parentNode.parentNode.id;  
        var trObj = document.getElementById(trId);  
        document.getElementById("tb").removeChild(trObj);  
    }  
</script>
로그인 후 복사

위 내용은 다음과 같습니다. code 에서는 먼저 본문에 테이블을 구성합니다. 후속 작업을 용이하게 하기 위해 thead 태그는 테이블 헤더를 나타내고 tbody 태그는 테이블 본문을 나타냅니다.

예제의 테이블에는 세 개의 열이 있는데 첫 번째 열은 이름, 두 번째 열은 성, 세 번째 열은 작업 열입니다.

작업 열에는 두 가지 작업이 포함되어 있습니다. 하나는 테이블에 행을 추가하는 것이고, 다른 하나는 현재 행을 삭제하는 것입니다. 행 추가 및 행 삭제 작업은 각각 두 개의 버튼에 연결되어 있습니다. 버튼을 클릭하면 해당 행 추가/삭제 작업이 트리거됩니다.

행 추가 방법

function add() {  
        var trObj = document.createElement("tr");  
        trObj.id = new Date().getTime();  
        trObj.innerHTML = "<td><input name=&#39;firstName&#39;/></td><td><input name=&#39;lastName&#39;/></td><td><input type=&#39;button&#39; value=&#39;Add&#39; onclick=&#39;add()&#39;> <input type=&#39;button&#39; value=&#39;Del&#39; onclick=&#39;del(this)&#39;></td>";  
        document.getElementById("tb").appendChild(trObj);  
    }
로그인 후 복사

첫 번째 줄에서 tr 요소, 즉 테이블 행을 생성합니다.

두 번째 줄 trObj.id = new Date().getTime() 새 줄에 id 속성을 추가하고 속성에 값을 할당한 후 현재 시스템의 밀리초를 가져옵니다. . 주로 삭제가 필요한 경우입니다. trObj.id = new Date().getTime(); 给改行添加id 属性,并给属性赋值,取当前系统的毫秒数,这个主要是删除的时候需要。

第三行,trObj.innerHTML = "<td><input name=&#39;firstName&#39;/></td><td><input name=&#39;lastName&#39;/></td><td><input type=&#39;button&#39; value=&#39;Add&#39; onclick=&#39;add()&#39;>

<input type=&#39;button&#39; value=&#39;Del&#39; onclick=&#39;del(this)&#39;></td>"; 给表格行赋值,通过innerHTMML属性,设置标签和 标签间的html代码内容,也就是要添加的行内容。

第四行,document.getElementById("tb").appendChild(trObj); 将创建好的表格行添加到表格主体中。

删除行方法

function del(obj) {  
    var trId = obj.parentNode.parentNode.id;  
    var trObj = document.getElementById(trId);  
    document.getElementById("tb").removeChild(trObj);  
}
로그인 후 복사

删除方法中传递了一个参数,在添加行方法中,我们可以看到删除方法del 中传递了this参数,页面代码中的this指代的是当前的HTML元素,即this所在的域。

第一行,var trId = obj.parentNode.parentNode.id; 获取当前元素的父节点的父节点的id,即要删除的行的id 。

第二行,var trObj = document.getElementById(trId); 获取要删除的行元素。

第三行,document.getElementById("tb").removeChild(trObj);

세 번째 줄, trObj.innerHTML = "<td><input name='firstName'/></td><td><input name='lastName'/>&lt ;/td><td><input type='button' value='Add' onclick='add()'>

<input type='button' value=' Del' onclick='del(this)'></td>"; 테이블 행에 값을 할당하고 태그와 네 번째 줄 document.getElementById("tb").appendChild(trObj)생성된 테이블 행을 테이블 본문에 추가합니다.

행 삭제 메소드

rrreee

행 추가 메소드에서 이 매개변수가 삭제 메소드 del에 전달되는 것을 볼 수 있습니다. HTML 요소, 즉 이 요소가 위치한

첫 번째 줄 var trId = obj.parentNode.parentNode.id는 현재 요소의 상위 노드의 상위 노드 ID, 즉 삭제할 행의 ID를 가져옵니다.

두 번째 줄인 var trObj = document.getElementById(trId)는 삭제할 행 요소를 가져옵니다.

세 번째 줄 document.getElementById("tb").removeChild(trObj)테이블 본문에서 이 줄을 삭제하세요.

Flaws

위 코드는 기본적으로 테이블에 행을 동적으로 추가하고 삭제하는 기능을 구현하지만 코드에는 여전히 결함이 있습니다. 주로 다음 두 가지 점에 있습니다.

1 테이블이 행을 추가하기 전이고 행 추가 후 테이블 너비가 변경됨

🎜행 추가 전🎜🎜🎜🎜🎜행 추가 후🎜🎜🎜🎜🎜행 추가 후 테이블 열이 넓어집니다🎜🎜2 브라우저에서 기본적으로 열리는 페이지가 깨졌습니다. 한자🎜🎜🎜🎜🎜필수 문자 인코딩을 설정하고 페이지 인코딩 형식을 수정해야 정상적으로 표시됩니다🎜

위 내용은 HTML에 테이블을 동적으로 추가하는 방법에 대한 분석 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿