일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- 인코딩
- study
- spring
- 디자인패턴
- 에러
- 오라클
- 우아한테크코스
- 독서리뷰
- 인프런
- Singleton
- 이펙티브자바
- 카카오톡1차
- 독서
- 공부
- 자바
- 알고리즘
- 람다
- JPA
- math
- Java
- Design Pattern
- Oracle
- 인강리뷰
- 회고
- 후기
- Eclipse
- 매핑
- javascript
- Head First Design Pattern
- 프로그래머스
- Today
- Total
Lee's Grow up
[Javascript/Jquery] TABLE 행 추가, 삭제, 체크된 table row 삭제 방법 본문
[Javascript/Jquery] TABLE 행 추가, 삭제, 체크된 table row 삭제 방법
효기로그 2019. 10. 14. 15:061. 개요
이번 포스팅에서는 테이블의 행의 추가/삭제를 javascript를 활용한 방법과 Jquery를 활용한
방법을 소개하겠습니다. 또한 check에 체크된 테이블의 row삭제하는 방법도 소개합니다.
시작하기에 앞서 기준이 되는 테이블의 내용은 아래와 같습니다.
1
2
3
4
5
6
|
<table id='testTable' align='center' width='200' border="1px; solid; black">
<tr>
<td><input type='button' value="행 추가하기" onClick="addRow();"/></td>
<td><input type='button' value="행 삭제하기" onClick="delRow();"/></td>
</tr>
</table>
|
2. 테이블에 ROW 추가하기
테이블에 값 추가하는 방법으로는 Javascript를 활용한 방법과 Jquery를 사용한 방법 2가지를 소개합니다.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
<script language="javaScript">
function addRow(){
// Javascript로 테이블에 행 추가 방법
var tableData = document.getElementById('testTable');
var cell1 = row.insertCell(0);
var cell2 = row.insertCell(1);
cell1.innerHTML = "<td><input type='checkbox' name='chkbox'></td>";
cell2.innerHTML = "<td>Javascript</td>";
// Jquery로 테이블에 행 추가 방법
$("#testTable ").append(
"<tr><td><input type='checkbox' name='chkbox'></td>"
+"<td>Jquery</td></tr>");
}
</script>
|
추가하기 버튼 클릭 후 ( addRow() 함수 호출 후 )
기존 테이블에 새로 2개의 행이 추가 된 것을 확인 할 수 있습니다.
Javascript의 경우 innerHTML을 통해서 cell 변수에 값을 넣어주는 방식이고
Jquery의 경우 append() 를통해서 태그를 추가해주는 방식입니다.
3. 테이블의 ROW 삭제
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<script language="javaScript">
function delRow(){
// Javascript로 테이블에 행 삭제 방법
var tableData = document.getElementById('testTable');
// Jquery로 테이블 행 삭제 방법
if($("#testTable tr").length < 2) return;
$("#testTable tr:last").remove();
}
</script>
|
삭제하기 버튼 클릭 후
추가 된 2개의 행이 삭제된 것을 확인 할 수 있습니다.
Javascript [본문 6행] 조건에 length를 주었기 때문에 맨 위 버튼 2개는 삭제되지 않고 함수를 리턴킵니다.
[본문 7행] 테이블의 인덱스는 0부터 시작하고 length는 크기를 반환하기 때문에 -1을 해줘서
마지막 행의 인덱스로 접근합니다.
Jquery같은 경우는 선택자를 통해서 해당 테이블의 자손인 tr의 마지막을 찾아서 삭제를 진행합니다.
4. 체크 된 ROW 삭제
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
<script language="javaScript">
function delRow(){
// javascript를 사용한 방법
var tableData = document.getElementById('testTable');
if(chkbox){
tableData.deleteRow(i);
i--;
}
}
// jquery를 사용한 방법
var checkRows = $("[name='chkbox']:checked");
for(var i =checkRows.length-1;i>-1;i--){
checkRows.eq(i).closest('tr').remove();
}
}
</script>
|
둘중 편한 방식을 사용하시면 됩니다.
Javascript의 경우 반복문을 테이블의 rows의 length로 걸었기 때문에 테이블의 row 삭제 후
작아진 length만큼 i의 값을 - 해주기 위해서 [본문 10행] 에서 i--를 실행합니다.