3 回答
TA贡献1841条经验 获得超3个赞
您可以用作class选择器,因为这对于多个元素来说是相同的。使用 jQuerydata来存储索引。
$i=0;
foreach ($form as $value) {
$input = '<input type="number" class="percentage" data-index="'.$i.'" value="'.$value->persentase.'" min="0" max="100" title="Progres">';
$inputdnone = '<input type="number" id="persentase'.$i.'" min="0" max="100" value="'.$value->persentase.'">'; //this input should not appear in view
$i++;
}
在jQuery部分,不需要使用循环,只需为percentage类编写更改函数。每当输入值更改时都会触发此操作:
$(".reportsForApps").on("change", ".percentage", function(){ // 'parentElementId' should be replaced with actual parent element id.
var tbpersentase = $(this).val();
var index = $(this).data("index");
$('#persentase'+index).val(tbpersentase);
});
TA贡献1829条经验 获得超7个赞
添加数据类型 attrdata-group="tbpersentase"并在函数中调用它
$input = null;
$inputdnone = null;
foreach ($form as $key => $value) { // you could also use $key value for increment
$input .= '<input type="number" data-group="tbpersentase" id="tbpersentase'.$key.'" min="0" max="100" value="'.$value.'" title="Progres">';
$inputdnone .= '<input type="hidden" id="persentase'.$key.'" min="0" max="100" value="'.$value.'">'; //this input should not appear in view
}
// place in html to echo results of dynamically created inputs from DB info
<?=$input?>
<?=$inputdnone?>
// JQuery 3.4.1
$( "input[data-group='tbpersentase']" ).change(function() {
var $this = $(this).val(); // get users value of the changing input field
var tbpersentaseID = $(this).attr('id'); // get the changing input fields ID so we can remove IDs alpha chars
var getID = tbpersentaseID.replace(/[^0-9]/g,''); // declare a new variable containing the numbers for the selected ID
var persentaseID = 'persentase' + getID; // Concatenate desired alpha ID name to selected key value
$("#"+persentaseID).val($this); // set value
});
在 chrome 中进行测试,并将 的值更改#persentase为在 中输入的值#tbpersentase,但保留 中的原始 ID #persentase。希望这就是您想要实现的目标。
另外,如果您想知道从数据库中获取了多少行,请count()
在 php.ini 中使用。
$form_count = count($form);
- 3 回答
- 0 关注
- 120 浏览
添加回答
举报