Как сделать данные доступными для всех строк в таблице - PullRequest
0 голосов
/ 15 октября 2018

Моя проблема в том, что выборка корректно работает в первом ряду

<script type="text/javascript">
  $(document).ready(function () {
        $("#tb3").on('input change', function () {

            $('#tb3 > tbody  > tr').each(function () {
                var code = $(this).find('#Product_Code').val();
                //var data = $("#tb3 tr:eq(1)").clone(true).appendTo("#tb3");
                //var code = data.find("Product_Code").val('');


                $.ajax({
                    type: "POST",
                    url: "<?php echo base_url();?>TipUp_Loan/fetch",
                    data: {
                        code: code
                    },
                    datatype: 'json',
                    success: function (data) {


                        var json = data,
                            obj = JSON.parse(json);


                        $("#Product_Name").val(obj.itemname);
                        $("#Rate").val(obj.salrate);
                        //alert(obj);


                    }
                });
            });
        });
    });
</script>

код таблицы:

<table>
    <thead>
        <tr>
            <th><a href="javascript:void(0);" id="multi" name="multiplerows" title="Add More Person"></a></th>
            <th>Product Code</th>
            <th>Product Name</th>
            <th>Qty</th>
            <th>Rate</th>
            <th>Amount</th>
        </tr>
    </thead>
    <tbody>
        <tr >
            <td><a href='javascript:void(0);' class='remove3'><span class='glyphicon glyphicon-remove'></span></a></td>
            <td>
                <input style="width:80px" type="text" id="Product_Code"  class="form-control input-xs Product_Code "  onkeyup="fetch()"  name="Product_Code[]" required>
            </td>
            <td ><input style="width:300px" type="text" id="Product_Name" class="form-control input-xs" name = "Prdtname[]"   > </td>
            <!--value="<?php echo $row['Product_Name']; ?>"-->
            <td><input style="width:80px" type="text" id="Qty" onkeyup="movetoNext(this, 'addMore3')" class="form-control input-xs"   name="Qty[]" required></td>
            <td><input style="width:100px" type="text" id="Rate"  class="form-control input-xs" value="" name="rate[]" required></td>
            <td><input style="width:150px" type="text" id="Value" class="form-control input-xs" name="amount[]" ></td>
            <th><a href="javascript:void(0);" id="addMore3" name= addmore title="Add More Person"><span class="glyphicon glyphicon-plus"></span></a></th>
        </tr>
    </tbody>
</table>

Код выборки:

public function fetch()
{   
    $this->load->model('User_model');
    $result = $this->User_model->fetch_name($_POST["code"]);

    echo json_encode($result);
    //echo 'hello'.$code;
}

Код модели:

public function fetch_name($code)
{
    $query = $this->db->query("select * FROM itemmaster where itcode = $code")->row_array();

    return $query;
}

Я пытаюсь получить сведения о продукте по коду продукта, когда пользователь нажимает клавишу табуляции ... что мне нужно изменить, чтобы сделать выборку доступной для всех строк таблицы. Спасибо заранее

1 Ответ

0 голосов
/ 15 октября 2018

Вы можете использовать onchange, как показано ниже

<input style="width:80px" type="text" id="Product_Code"  class="form-control input-xs Product_Code " onchange="fetchdetails(this)"  name="Product_Code[]" required>

Функция fetchdetails:

function fetchdetails(e) {
     var code = e.value;
           $.ajax({
                type: "POST",
                url: "<?php echo base_url();?>TipUp_Loan/fetch",
                data: {
                    code: code
                },
                datatype: 'json',
                success: function (data) {
                    var json = data,
                        obj = JSON.parse(json);
                    var prodName = $(e).closest('tr').find('#Product_Name');
                    $(prodName).val(obj.itemname);
                    var rate = $(e).closest('tr').find('#Rate');
                    $(rate).val(obj.salrate);
                }
            });
        }

Вы можете использовать ее для динамических строк, она будет извлекать текущую строку и заполнять записи.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...