我是Codeigniter的新手,所以我不知道该怎么做。
实际上,我的视图页面有五行,我通过 for 循环生成,其中每行包含两个选择框和两个输入框。我不知道如何首先在jQuery中获取这些值,然后传递给控制器。实际上我知道如何从一个简单的文本框中获取值,但是因为我在循环中生成它们并给它们一个单独的 id,所以我不知道如何在 jQuery 中获取值然后传递给控制器。
这是我的看法
<tr>
<th>Category:</th>
<th>Items:</th>
<th>Selling Price:</th>
<th>quantity:</th>
</tr>
<?php for ($i = 0; $i < 5; $i++) {
?>
<tr> //Categories
<td><?php echo form_dropdown('cat_id', $records2, '#',
"id='category_".$i."' onchange='getItems(this.value,".$i.")' ");?>
</td>
<!-- Items -->
<td>form_dropdown('item_id', $records3, '#', "id='items_".$i."'"); ?> </td>
<!-- end of Items -->
<td> <?php echo form_input($price); ?></td>
<td><?php echo form_input($quantity); }?></td>
项目选项基于类别选择,这意味着如果我从类别中选择某个选项,则针对类别的项目将显示在第二个选择框中。
这是我的 Javascript,用于前两个选择框的功能
<script type="text/javascript">
function getItems(category_id,index) {
$("#items_" + index + " > option").remove();
$.ajax({
type: "POST",
url: "stockInController/get_Items/"+category_id,
success: function(items)
{
$.each(items,function(item_id,item_name)
{
var opt = $('<option />');
opt.val(item_id);
opt.text(item_name);
$('#items_'+ index).append(opt);
});
}
});
}
</script>
现在问题就在这里;我想从所有行中获取值,然后传递给控制器。
这是用于捕获然后将值发送到控制器的 javascript
<script type="text/javascript">
$('#btns').click(function() { // $("#form").serialize()
在这里,我做的不对,首先我不知道如何在这里获取项目和类别的值,然后另一件事是如何能够获取多个文本框值,因为有五行,以及其中的文本值已填写 将发送
var item_id = $('#items').val();
var item_id = $('#items').val();
var price = $('#price').val();
var quantity = $('#quantity').val();
var form_data = {
cat_id: $('#cat_id').val(),
quantity: $('#quantity').val(),
item_id: $('#items').val(),
};
$.ajax({
url: "<?php echo site_url('salesController/addSales'); ?>",
type: 'POST',
data: form_data,
dataType: 'json',
success: function(msg) {
if(msg.res == 1)
{
alert("true");
}
else{
alert("false");
}
}
});
return false;
});
</script>
这是我的控制器,我也不知道在这里获取多个值。
这是我正在做的代码,我知道我错了,但我不知道如何改正
$data = array(
'cat_id' => $this->input->post('cat_id'),
'item_id' => $this->input->post('item_id'),
'price' => $this->input->post('sales_date'),
'quantity' => $this->input->post('sales_bill_no'),
);