리자

동적테이블, 행추가, 열추가, 행삭제, 열삭제

· 17년 전 · 4235

옵션에 사용하기 위해 만들어본 코드입니다.

테스트 해본 코드이므로 별 이상은 없을것 같습니다.

동적테이블 정보가 필요하신 분들은 참고하세요.

IE, FF, 크롬에서 실행되는 것을 확이하였습니다.



<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN">
<HTML>
<HEAD>
<TITLE> New Document </TITLE>
<META NAME="Generator" CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<META NAME="Keywords" CONTENT="">
<META NAME="Description" CONTENT="">
</HEAD>

<BODY>

<form method=post action="a2_post.php">
<input type=button value="행추가" onclick="add_tr();">
<input type=button value="열추가" onclick="add_td();">
<input type=button value="행삭제" onclick="del_row();">
<input type=button value="열삭제" onclick="del_col();">
<table id='tbl' border=1>
    <thead id='thd'>
        <tr>
            <td>
                <input type=text name=opty size=4>
                <input type=text name=optx size=4>
            </td>
            <td>
                <input type=text name='optx_subj[]' size=10>
            </td>
        </tr>
    </thead>
    <tbody id='tbd'>
        <tr>
            <td><input type=text name='opty_subj[]' size=10></td>
            <td><input type=text name='opt[][]' size=10></td>
        </tr>
    </tbody>
</table>

<input type=submit>
</form>

<span id=msg></span>

<script>
var tbl = document.getElementById('tbl');
var thd = document.getElementById('thd');
var tbd = document.getElementById('tbd');
var tr = null;
var td = null;
var x=1, y=1;

function add_tr()
{
    // 행 제목 추가
    tr = document.createElement('tr');
    tbd.appendChild(tr);
    td = document.createElement('td');
    tr.appendChild(td);
    add_input('opty_subj[]');

    // 열의 갯수에 따라 추가된 행의 열 추가
    var thd_td = thd.getElementsByTagName('td');
    for (i=0; i<thd_td.length-1; i++)
    {
        td = document.createElement('td');
        tr.appendChild(td);
        add_input('opt[][]');
    }
}

function add_td()
{
    // 열 제목 추가
    var thd_tr = thd.getElementsByTagName('tr');
    td = document.createElement('td');
    thd_tr[0].appendChild(td);
    add_input('optx_subj[]');

    var tbd_tr = tbd.getElementsByTagName('tr');
    for (i=0; i<tbd_tr.length; i++) {
        //var td_tag = tr_tag[i].getElementsByTagName("td");
        td = document.createElement('td');
        tbd_tr[i].appendChild(td);
        add_input('opt[][]');
    }
}

function add_input(name)
{
    var inp = document.createElement('input');
    inp.setAttribute('type', 'text');
    inp.setAttribute('size', '10');
    inp.setAttribute('name', name);
    td.appendChild(inp);
}

function del_row()
{
    var tbd_tr = tbd.getElementsByTagName('tr');
    //document.getElementById('msg').innerHTML = tbd_tr.length;
    if (tbd_tr.length > 1)
        tbd.deleteRow(tbd_tr.length-1);
}

function del_col()
{
    var thd_tr = thd.getElementsByTagName('tr');
    var thd_td = thd.getElementsByTagName('td');
    //document.getElementById('msg').innerHTML = thd_td.length;
    if (thd_td.length > 2) {
        thd_tr[0].deleteCell(thd_td.length-1);

        var tbd_tr = tbd.getElementsByTagName('tr');
        for (i=0; i<tbd_tr.length; i++) {
            var tr_td = tbd_tr[i].getElementsByTagName('td');
            tbd_tr[i].deleteCell(tr_td.length-1);
        }
    }
}
</script>

</BODY>
</HTML>

[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]
|
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
16년 전 조회 2,139
17년 전 조회 4,425
17년 전 조회 2,920
17년 전 조회 2,857
17년 전 조회 1,592
17년 전 조회 1,230
17년 전 조회 3,934
17년 전 조회 1,608
17년 전 조회 1,600
17년 전 조회 2,099
17년 전 조회 1,872
17년 전 조회 1,487
17년 전 조회 3,909
17년 전 조회 1,746
17년 전 조회 3,119
17년 전 조회 3,001
17년 전 조회 1,032
17년 전 조회 1,841
17년 전 조회 1,582
17년 전 조회 1,844
17년 전 조회 2,634
17년 전 조회 3,018
17년 전 조회 3,211
17년 전 조회 3,316
17년 전 조회 1,453
17년 전 조회 1,410
17년 전 조회 2,243
17년 전 조회 1,965
17년 전 조회 2,282
17년 전 조회 2,804
17년 전 조회 3,258
17년 전 조회 2,356
17년 전 조회 1,626
17년 전 조회 3,198
17년 전 조회 3,064
17년 전 조회 3,038
17년 전 조회 3,906
17년 전 조회 2,580
17년 전 조회 2,399
17년 전 조회 2,651
17년 전 조회 2,887
17년 전 조회 2,606
17년 전 조회 1,446
17년 전 조회 1,890
17년 전 조회 1,484
17년 전 조회 1,907
17년 전 조회 2,503
17년 전 조회 8,689
17년 전 조회 3,148
17년 전 조회 4,236
17년 전 조회 1,979
17년 전 조회 3,654
17년 전 조회 1,547
17년 전 조회 1,380
17년 전 조회 2,317
17년 전 조회 1,309
17년 전 조회 1,623
17년 전 조회 1,453
17년 전 조회 2,522
17년 전 조회 1,491
17년 전 조회 1,082
17년 전 조회 1,217
17년 전 조회 3,093
17년 전 조회 2,157
17년 전 조회 1,965
17년 전 조회 1,207
17년 전 조회 2,442
17년 전 조회 1,165
17년 전 조회 1,124
17년 전 조회 1,364
17년 전 조회 2,727
17년 전 조회 2,384
17년 전 조회 2,471
17년 전 조회 1,172
17년 전 조회 1,286
17년 전 조회 3,237
17년 전 조회 2,823
17년 전 조회 4,088
17년 전 조회 2,249
17년 전 조회 2,345
17년 전 조회 1,394
17년 전 조회 2,514
17년 전 조회 2,201
17년 전 조회 2,959
17년 전 조회 2,468
17년 전 조회 1,631
17년 전 조회 2,425
17년 전 조회 1,582
17년 전 조회 1,171
17년 전 조회 2,232
17년 전 조회 2,877
17년 전 조회 4,052
17년 전 조회 3,141
17년 전 조회 1,408
17년 전 조회 1,706
17년 전 조회 2,238
17년 전 조회 1,543
17년 전 조회 1,716
17년 전 조회 2,710
17년 전 조회 2,133
🐛 버그신고