Tablo içeren bir sayfam var. tbody
'da angularjs
aracılığıyla verileri gösteriyorum. thead
'da tbody
ile aynı satır var, ancak boş ve ben giriş alanı ve click
bir yere (odağı kayboldu) doldurduğumda, bir satır tabloya ekler (thead
). Ve doldurulmuş satırda biraz bayrak yapmam gerekiyor - rowAdded = true
, çünkü o olmadan bir satırın girişini tıklıyorum ve satırlar ekliyor. Ve bir başka sorun da satırların table
sonuna eklenmesidir. bu senaryo üzerinde tüm çalışır:Tablodaki bazı konumlara yeni satırlar nasıl eklenir
var tbody = $('.table-timesheet thead');
tbody.on('blur', ':text', function() {
var tr = $(this).closest('tr'),
notEmpty = $(':text', tr).filter(function() {
return $.trim($(this).val()) != '';
}).length;
if (notEmpty) {
$('.note-input').css('width', '88%').css('float', 'left');
$('.timesheet-delete-button').css('display', 'block');
//tr.clone(true).appendTo(tbody).find(':text').val('');
insRow();
}
});
function deleteRow(row) {
var i = row.parentNode.parentNode.rowIndex;
document.getElementById('table-body').deleteRow(i);
}
function insRow() {
var table = document.getElementById('table-body');
var newRow = table.rows[1].cloneNode(true);
var len = table.rows.length;
newRow.cells[0].innerHTML = len;
var inp1 = newRow.cells[1].getElementsByTagName('input')[0];
inp1.id += len;
inp1.value = '';
var inp2 = newRow.cells[2].getElementsByTagName('input')[0];
inp2.id += len;
inp2.value = '';
table.appendChild(newRow);
}
plunker benim örnek vardır: http://plnkr.co/edit/rcnwv0Ru8Hmy7Jrf9b1C?p=preview
aradığınızı mı Sorunuzu açıkça okumak biraz zor ve bence birde birden çok soru var. Yeni satırı tablo başlığına eklemeyi mi (thead)? Eğer öyleyse neden tbody kullanmak istemiyorsunuz? Tipik olarak thead, sütunların sahip olacağı hakkında bilgi içindir. Bir satır eklemenin tüm genel işlevselliği kırılmış gibi görünüyor çünkü her seferinde sütunlardan birinde bilgi eklediğimde yeni bir satır oluşturuyor. – IfTrue
Demo, içinde açısal kod bulunmuyor. Gerçekten çok fazla DOM manipülasyonu yapıyorsunuz ve ayrıca document.ready'ye güveniyor gibisiniz. Açısal uygulama içinde çalışmak için Yaklaşım yanlıştır. Kendi satır eklemelerinizi yapmadan görünüm oluşturmak için veri modelini güncellemeniz gerekir. Lütfen daha fazla yardım istiyorsanız, en az açısal en azından kontrolcünüzle önyükleme yaparsanız lütfen – charlietfl
@ HUSTLIN ile angular.js etiketini de eklemelisiniz. –