리자

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

아래의 코드에는 버그가 있네요. 다시 올립니다.


<!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_row();">
<input type=button value="열추가" onclick="add_col();">
<input type=button value="행삭제" onclick="del_row();">
<input type=button value="열삭제" onclick="del_col();">
<table id='stock_table' border=1>
    <thead id='stock_thead'>
        <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='stock_tbody'>
        <tr>
            <td><input type=text name='opty_subj[]' size=10></td>
            <td><input type=text name='opt[0][]' size=10></td>
        </tr>
    </tbody>
</table>

<input type=submit>
</form>

<span id=msg></span>

<script>
var stock_table = document.getElementById('stock_table');
var stock_thead = document.getElementById('stock_thead');
var stock_tbody = document.getElementById('stock_tbody');
var stock_tr = null;
var stock_td = null;
var stock_x = 0;
var stock_y = 0;
var msg = document.getElementById('msg');

function add_row()
{
    // 행 제목 추가
    stock_tr = document.createElement('tr');
    stock_tbody.appendChild(stock_tr);
    stock_td = document.createElement('td');
    stock_tr.appendChild(stock_td);
    add_input('opty_subj[]');
    stock_y++;

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

function add_col()
{
    // 열 제목 추가
    var stock_thead_tr = stock_thead.getElementsByTagName('tr');
    stock_td = document.createElement('td');
    stock_thead_tr[0].appendChild(stock_td);
    add_input('optx_subj[]');

    var stock_tbody_tr = stock_tbody.getElementsByTagName('tr');
    for (i=0; i<stock_tbody_tr.length; i++) {
        stock_td = document.createElement('td');
        stock_tbody_tr[i].appendChild(stock_td);
        add_input('opt['+i+'][]');
    }
}

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

function del_row()
{
    var stock_tbody_tr = stock_tbody.getElementsByTagName('tr');
    if (stock_tbody_tr.length > 1) {
        stock_tbody.deleteRow(stock_tbody_tr.length-1);
        stock_y--;
    }
}

function del_col()
{
    var stock_thead_tr = stock_thead.getElementsByTagName('tr');
    var stock_thead_td = stock_thead.getElementsByTagName('td');
    if (stock_thead_td.length > 2) {
        stock_thead_tr[0].deleteCell(stock_thead_td.length-1);

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

</BODY>
</HTML>

[이 게시물은 관리자님에 의해 2011-10-31 17:16:08 PHP & HTML에서 이동 됨]
|

댓글 3개

이제 영카트4에 멀티옵션이 들어가나봐요??? ^^

그런데 이런거는 어때요????
http://recall.tistory.com/169
헉 멀티옵션?!...

얼마전 허접멀티옵션 작업 했었는데.. 기다릴걸 그랬나;
<table ....
<tr id="first" >
<td>1</td>


function add() {
var root = document.getElementById( "first").parentNode;
var clone= document.getElementById( "first").cloneNode( true);

var cells= clone.getElementsByTagName("input");

for( i=0; i< cells.length; i++) if( cells[i].type=="text") cells[i].value='';

clone.firstChild.innerText=++seq;
root.appendChild( clone);
}

<td안에 <input type="text"가 있는 경우.......
댓글을 작성하시려면 로그인이 필요합니다. 로그인

프로그램

+
제목 글쓴이 날짜 조회
17년 전 조회 2,404
17년 전 조회 2,150
17년 전 조회 4,430
17년 전 조회 2,932
17년 전 조회 2,867
17년 전 조회 1,600
17년 전 조회 1,241
17년 전 조회 3,947
17년 전 조회 1,616
17년 전 조회 1,611
17년 전 조회 2,111
17년 전 조회 1,882
17년 전 조회 1,495
17년 전 조회 3,919
17년 전 조회 1,755
17년 전 조회 3,130
17년 전 조회 3,009
17년 전 조회 1,040
17년 전 조회 1,850
17년 전 조회 1,591
17년 전 조회 1,852
17년 전 조회 2,642
17년 전 조회 3,022
17년 전 조회 3,217
17년 전 조회 3,326
17년 전 조회 1,462
17년 전 조회 1,419
17년 전 조회 2,251
17년 전 조회 1,974
17년 전 조회 2,288
17년 전 조회 2,815
17년 전 조회 3,264
17년 전 조회 2,365
17년 전 조회 1,632
17년 전 조회 3,205
17년 전 조회 3,071
17년 전 조회 3,046
17년 전 조회 3,914
17년 전 조회 2,588
17년 전 조회 2,405
17년 전 조회 2,656
17년 전 조회 2,896
17년 전 조회 2,611
17년 전 조회 1,454
17년 전 조회 1,896
17년 전 조회 1,487
17년 전 조회 1,912
17년 전 조회 2,511
17년 전 조회 8,697
17년 전 조회 3,157
17년 전 조회 4,244
17년 전 조회 1,984
17년 전 조회 3,661
17년 전 조회 1,555
17년 전 조회 1,386
17년 전 조회 2,322
17년 전 조회 1,315
17년 전 조회 1,630
17년 전 조회 1,464
17년 전 조회 2,532
17년 전 조회 1,500
17년 전 조회 1,089
17년 전 조회 1,225
17년 전 조회 3,099
17년 전 조회 2,162
17년 전 조회 1,969
17년 전 조회 1,216
17년 전 조회 2,451
17년 전 조회 1,169
17년 전 조회 1,129
17년 전 조회 1,376
17년 전 조회 2,740
17년 전 조회 2,394
17년 전 조회 2,480
17년 전 조회 1,178
17년 전 조회 1,297
17년 전 조회 3,244
17년 전 조회 2,830
17년 전 조회 4,098
17년 전 조회 2,260
17년 전 조회 2,355
17년 전 조회 1,405
17년 전 조회 2,523
17년 전 조회 2,208
17년 전 조회 2,970
17년 전 조회 2,479
17년 전 조회 1,640
17년 전 조회 2,433
17년 전 조회 1,590
17년 전 조회 1,177
17년 전 조회 2,237
17년 전 조회 2,884
17년 전 조회 4,060
17년 전 조회 3,148
17년 전 조회 1,415
17년 전 조회 1,706
17년 전 조회 2,246
17년 전 조회 1,548
17년 전 조회 1,725
17년 전 조회 2,717
🐛 버그신고