2016-06-21 111 views
0

我有以下代碼。如何使用動態生成的表動態添加行

arrayToTable = function(data, options = {}){ 
    var table = $('<table />'), 
     thead, 
     tfoot, 
     rows = [], 
     row, 
     i, j, 
     defaults = { 
      th: true, // should we use th elemenst for the first row 
      thead: false, //should we incldue a thead element with the first row 
      tfoot: false, // should we include a tfoot element with the last row 
      attrs: {} // attributes for the table element, can be used to 
     } 

    options = $.extend(defaults, options); 

    table.attr(options.attrs) 

    // loop through all the rows, we will deal with tfoot and thead later 
    for(i = 0; i < data.length; i++){ 
     row = $('<tr />'); 
     for(j = 0; j < data[i].length; j++){ 
      if(i == 0 && options.th){ 
       row.append($('<th />').html(data[i][j])); 
      }else{ 
       row.append($('<td />').html("<input type='text' name='fname'>")); 
      } 
     } 
     rows.push(row); 
    } 

    // if we want a thead use shift to get it 
    if(options.thead){ 
     thead = rows.shift(); 
     thead = $('<thead />').append(thead); 
     table.append(thead); 
    } 

    // if we want a tfoot then pop it off for later use 
    if(options.tfoot){ 
     tfoot = rows.pop(); 
    } 

    // add all the rows 
    for (i = 0; i < rows.length; i++) { 
     table.append(rows[i]); 
    }; 

    // and finally add the footer if needed 
    if(options.tfoot){ 
     tfoot = $('<tfoot />').append(tfoot); 
     table.append(tfoot); 
    } 
    return table; 
} 

    var data = [ 
     ['Name', 'Age', 'Email'], 
     ['John Doe', '27', '[email protected]'], 
     ['Jane Doe', '29', '[email protected]'] 
    ]; 

    var table = arrayToTable(data, { 
     thead: true, 
     attrs: {class: 'table'} 
    }) 

    $('body').append(table); 

和它產生這樣的:

http://jsfiddle.net/bytg16k6/

我需要一個按鈕,新行dinamycally添加到它,但我堅持認爲

回答

2

你表中有一類(可如果您有多個此類的表,則有一個ID),那麼您可以通過點擊類別爲'add-row'的按鈕來使用以下代碼:

$('.add-row').on('click', function() { 
    $('.table').append('<tr><td>test</td><td>test</td><td>test</td></tr>'); 
    }); 

http://jsfiddle.net/bytg16k6/1/

請注意,上面的代碼只是一個例子。