반응형
table td text에 class명이 동일한 값이 위아래로 있을 경우 병합해주는 함수입니다.
tbody의 병합할 컬럼 번호를 호출해서 값을 비교하고 있습니다.
저는 시군구 컬럼과 읍면동 컬럼을 병합하고 있습니다.
아래 예제를 통해서 다양하게 응용하시면 될 것 같습니다.
<style>
table {
width: 100%;
border: 1px solid #444444;
}
th, td {
border: 1px solid #444444;
text-align: center;
}
</style>
<script src="https://code.jquery.com/jquery-3.5.1.min.js"></script>
<button type="button" onclick="merge();" style="border-style:solid;">병합하기</button>
<table>
<thead>
<tr>
<th>순번</th>
<th>이름</th>
<th>시군구</th>
<th>읍면동</th>
</tr>
</thead>
<tbody class="infoTbody">
<tr>
<td>1</td>
<td>홍길동</td>
<td class='seoul'>서울특별시</td>
<td class='seocho'>서초구</td>
</tr>
<tr>
<td>2</td>
<td>이순신</td>
<td class='seoul'>서울특별시</td>
<td class='gangnam'>강남구</td>
</tr>
<tr>
<td>3</td>
<td>심봉사</td>
<td class='gyeonggi'>겅기도</td>
<td class='bucheon'>부천시</td>
</tr>
<tr>
<td>4</td>
<td>심청이</td>
<td class='gyeonggi'>경기도</td>
<td class='bucheon'>부천시</td>
</tr>
<tr>
<td>5</td>
<td>유관순</td>
<td class='seoul'>서울특별시</td>
<td class='yeongdeungpo'>영등포구</td>
</tr>
</tbody>
</table>
<script>
$.fn.mergeRowspan = function (colIdx) {
return this.each(function () {
var that;
$('tr', this).each(function (row) {
$('td:eq(' + colIdx + ')', this).filter(':visible').each(function (col) {
if ($(this).attr('class') == $(that).attr('class')) {
rowspan = $(that).attr("rowspan") || 1;
rowspan = Number(rowspan) + 1;
$(that).attr("rowspan", rowspan);
$(this).hide();
} else {
that = this;
}
that = (that == null) ? this : that;
});
});
});
};
function merge(){
$('.infoTbody').mergeRowspan(2);
$('.infoTbody').mergeRowspan(3);
}
</script>
↓↓↓↓↓ 결과화면
반응형
'개발이야기 > 자바스크립트' 카테고리의 다른 글
[자바스크립트] 오늘 하루 열지 않기 / 닫기 (레이어 팝업) (0) | 2022.10.21 |
---|---|
[자바스크립트] Apexcharts 사용법, 예제, 차트 그리기 (0) | 2022.10.20 |
[자바스크립트] javascript 테이블 정렬하기 (table sort) (2) | 2022.10.13 |
[자바스크립트] javascript 숫자 콤마 찍기 (number_format) (0) | 2022.10.13 |
[자바스크립트] javascript url 정규식, 유효성 검사 (0) | 2022.10.13 |
댓글