我有一个带有New Row函数脚本的表单。然后我从该站点添加了一个新脚本导航表单字段 Form Navigation script
导航脚本仅在第 1 行中正常工作。我可以使用箭头键在字段之间移动(从右到左,从左到右)。如果我添加新行,我可以移至第 2 行(从上到下),但无法移回第 1 行(从下到上) >)并且我也无法在第 2 行 中的字段之间移动(从右到左,从左到右)。如果我再次添加新行,第 3 行导航脚本根本不起作用,我只能从第 1 行移动到< em>第 2 行(从上到下),第 2 行到第 3 行不起作用。
这是我的代码,New Row 脚本:
var row_id = 1;
function addRow(tableID) {
var table = document.getElementById(tableID);
var rowCount = table.rows.length;
var row = table.insertRow(rowCount);
var colCount = table.rows[0].cells.length;
row.id = 'id' + row_id;
row_id++;
for(var i=0; i<colCount; i++) {
var newcell = row.insertCell(i);
newcell.innerHTML = table.rows[0].cells[i].innerHTML;
//alert(newcell.childNodes);
switch(newcell.childNodes[0].type) {
case "text":
newcell.childNodes[0].value = "";
break;
case "checkbox":
newcell.childNodes[0].checked = false;
break;
case "select-one":
newcell.childNodes[0].selectedIndex = 0;
break;
case "select":
newcell.childNodes[0].selectedIndex = 0;
break;
default:
newcell.childNodes[0].value = "";
break;
}
}
}
表单代码:
<div class="row">
<div class="col-md-12">
<div class="table-responsive">
<table class="table table-bordered table-hover table-striped sticky-header">
[....]
<tbody id="dataTable2">
<?php if(!isset($dtdetail)) {;
if(isset($message)) {
for ($i=0; $i < $jmldtl; $i++) { ?>
<tr>
<td>
<input type="text" name="tp_sal[]" id="tp_sal" size="5" value="<?php echo set_value('tp_sal['.$i.']'); ?>"/></td>
<td>
<input type="text" name="r_tpc_1[]" id="r_tpc_1" size="5" value="<?php echo set_value('r_tpc_1['.$i.']'); ?>"/></td>
<td>
<input type="text" name="r_tpc_2[]" id="r_tpc_2" size="10" value="<?php echo set_value('r_tpc_2['.$i.']'); ?>"/></td>
<td>
<input type="text" name="r_tpc_3[]" id="r_tpc_3" size="15" value="<?php echo set_value('r_tpc_3['.$i.']'); ?>"/></td>
<td>
<input type="text" name="r_etr_1[]" id="r_etr_1" size="13" value="<?php echo set_value('r_etr_1['.$i.']'); ?>"/></td>
</tr>
<?php } } else { ?>
<tr>
<td>
<input type="text" name="tp_sal[]" id="tp_sal" size="5" value="<?php $a=set_value('tp_sal'); echo $a; ?>"/></td>
<td>
<input type="text" name="r_tpc_1[]" id="r_tpc_1" size="5" value="<?php $a=set_value('r_tpc_1'); echo $a; ?>"/></td>
<td>
<input type="text" name="r_tpc_2[]" id="r_tpc_2" size="10" value="<?php $a=set_value('r_tpc_2'); echo $a; ?>"/></td>
<td>
<input type="text" name="r_tpc_3[]" id="r_tpc_3" size="15" value="<?php $a=set_value('r_tpc_3'); echo $a; ?>"/></td>
<td>
<input type="text" name="r_etr_1[]" id="r_etr_1" size="13" value="<?php $a=set_value('r_etr_1'); echo $a; ?>"/></td>
</tr>
<?php } } else {
foreach($dtdetail as $detail) { ?>
<tr>
<td>
<input type="text" name="tp_sal[]" id="tp_sal" size="5" value="<?php echo $detail->tp_sal; ?>"/></td>
<td>
<input type="text" name="r_tpc_1[]" id="r_tpc_1" size="5" value="<?php echo $detail->r_tpc_1; ?>"/></td>
<td>
<input type="text" name="r_tpc_2[]" id="r_tpc_2" size="10" value="<?php echo $detail->r_tpc_2; ?>"/></td>
<td>
<input type="text" name="r_tpc_3[]" id="r_tpc_3" size="15" value="<?php echo $detail->r_tpc_3; ?>"/></td>
<td>
<input type="text" name="r_etr_1[]" id="r_etr_1" size="13" value="<?php echo $detail->r_etr_1; ?>"/></td>
</tr>
<?php } } ?>
</tbody>
<tfoot class="bg-primary">
<tr>
<td colspan="31" align="center">
<?php if(!isset($dtdetail)) {?>
<button type="button" class="btn btn-sm btn-info" onClick="addRow('dataTable2')">New Row</button>
<?php } else { ?>
<button type="button" class="btn btn-sm btn-info" onClick="addRow('dataTable2')">New Row</button>
<?php } ?>
</td>
</tr>
</tfoot>
[.....]
<?php
$this->load->view('template/js2');
?>
以及 js2 文件中的表单导航脚本:
<script type="text/javascript">
/*!
* formNavigation
* Copyright 2013 Ole Bjørn Michelsen <http://ole.michelsen.dk/>
* MIT license
*/
(function ($) {
$.fn.formNavigation = function () {
$(this).each(function () {
$(this).find('input').on('keyup', function(e) {
switch (e.which) {
case 39:
$(this).closest('td').next().find('input').focus(); break;
case 37:
$(this).closest('td').prev().find('input').focus(); break;
case 40:
$(this).closest('tr').next().children().eq($(this).closest('td').index()).find('input').focus(); break;
case 38:
$(this).closest('tr').prev().children().eq($(this).closest('td').index()).find('input').focus(); break;
}
});
});
};
})(jQuery);
</script>
<script type="text/javascript">
$(document).ready(function () {
$('.table').formNavigation();
});
</script>
最佳答案
问题
发生这种情况是因为导航脚本仅适用于运行时的表中的行。因此,表单导航脚本在文档就绪事件上运行:
$(document).ready(function () {
$('.table').formNavigation();
});
当页面的 HTML 结构完全加载时(即在调用 addRow() 函数之前),会发生此事件。当调用 addRow() 函数时,它会添加一个新行,但这个新行没有应用表单导航事件处理程序。
解决方案
要解决此问题,请将 $(row).formNavigation();
添加到 addRow() 函数的末尾。
关于javascript - 使用箭头键导航表单字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36416103/