【发布时间】:2017-04-26 17:08:42
【问题描述】:
我有一个按钮的函数,它在这样的点击事件上被调用。一旦点击,一个元素的副本会立即插入到点击按钮的行之后。我需要更改一些元素的 ID 和名称新插入的行。
<tr class="tr_38">
<td>Maths [ Math01 ]</td>
<td>Required</td>
<td>
<select style="width: 250px;" name="TeacherID[2318]" id="TeacherID[2318]">
<option selected="" value="132">Dawn Herus - [ID : 132]</option>
<option value="246">Margaret Wilson - [ID : 246]</option>
</select>
</td>
<td>
<input class="date hasDatepicker" id="ExamDate_2318" name="ExamDate[2318]" value="02/28/2017" type="text">
<input style="width: 100px;" id="ExamTime_2318" name="ExamTime[2318]" value="8:00" type="text">
</td>
<td><input value="+" class="more-38-0 more_button" type="button">
</td>
</tr>
jquery函数:
var counter = -1;
$(document).on ('click','.more_button',function(){
var courseID='';
var row_classname = $(this).closest('tr').prop('class');
$.each($(this).prop('class').split(' '), function(i, name) {
if (name.indexOf('more-') > -1) {
courseID = name.split('-')[1];
return false;
}
});
var newrow = '<tr class="'+row_classname+'"><td>'+$(this).parent().parent().find('td:eq(0)').text()+
'</td><td>'+$(this).parent().parent().find('td:eq(1)').text()+
'</td><td>'+$(this).parent().parent().find('td:eq(2)').html()+'</td><td>'+
$(this).parent().parent().find('td:eq(3)').html()+'</td><td><input type="button" value="+" class="more-'+
courseID+'-1 more_button"><input type="button" class="remove" value="X">'+
'</td></tr>';
$newrow = $(newrow);
$(newrow).insertAfter($(this).closest('tr'));
$newrow.find('td:eq(2)').find('select').prop('id','TeacherID['+counter+']');//.prop('name','TeacherID['+counter+']');
alert($newrow.find('td:eq(2)').html());
$newrow.find('td:eq(3)').find('input[id^="ExamDate_"]').prop('id','ExamDate_'+counter).prop('name','ExamDate['+counter+']');
$newrow.find('td:eq(3)').find('input[id^="ExamTime_"]').prop('id','ExamTime_'+counter).prop('name','ExamTime['+counter+']');
alert($newrow.find('td:eq(3)').html());
$(this).hide();
counter--;
});
当我在修改元素的 ID 和名称后检查 alert() 时,警报显示已更改的值,但 DOM 没有更改。
【问题讨论】:
-
@ProgrammerV5 对不起,我没有得到你。
-
现在修改你的代码。
-
@ProgrammerV5 感谢您的支持兄弟..等待
标签: jquery dom insertafter