1

我对jquery知之甚少,所以如果我没有多大意义,请原谅。

我有一个表,它的行是从 php db 查询中填充的(行数会有所不同),在这种情况下有两行数据。这是 php 生成的 html 表的一部分。

<table border=1 width=800px id=workout>
 <tr>
 <th width=300px id=clients>Client</th>
 <th width=200px id=movements>Movements</th>
 <th>X Completed</th>
 </tr>

<tr>
<td><input type="hidden" name="client_id[]" class="clientval" value="1"></td>   
<td>
<select name="movement[]" width=200 class='typeval' onchange='changeMovement()'>
              <option value="select">Select...</option>
              <option>Key Movement</option>
              <option>Movement -1</option>
              <option selected="selected" >Movement -2</option>
              <option>Movement -3</option>
              <option>Movement -4</option>
        </select>
</td>
<td><label id="count"></label></td>
</tr>

<tr>
<td><input type="hidden" name="client_id[]" class="clientval" value="8">
<td>
<select name="movement[]" width=200 class='typeval' onchange='changeMovement()'>
              <option value="select">Select...</option>
              <option>Key Movement</option>
              <option>Movement -1</option>
              <option selected="selected" >Movement -2</option>
              <option>Movement -3</option>
              <option>Movement -4</option>
        </select>
</td>
<td><label id="count"></label></td>
</tr>

我将 和 的值传递movementclient_idjquery POST,因此我可以对数据运行 php 查询并返回结果。如何根据选择菜单所在的行传递所选移动的值和 client_id。

例如:如果用户更改第二行的移动下拉菜单,我想将client_id和发送selected>Movement<到 jQuery 函数。现在它只是得到我表的第一行,仅此而已。

这是我编辑的 jQuery:

编辑:

<script type="text/javascript">

var typeval,clientval, class_id;
$('.typeval').on('change', function(){
    movement =  $(".typeval option:selected").val();
    client_id = $(this).parents('tr').find('input.clientval').val();
    class_id = $(<? echo $class_id; ?>).val();

    //console.log($(this).parents('tr').find('input.clientval').val(), $(this).val());
    $.ajax(
    { url: "movement_count.php",
      type: "post",
      data: {typeval:typeval, client_id: clientval, class_id :},
      dataType: "json",
      });

    success: (function(output) {
    alert(output);
    $(".count").html(output);
    })
 });

</script>   
4

5 回答 5

2

由于您使用的是 jQuery,因此我会这样做。移除内联 JavaScript 并绑定到选择元素的更改事件。

var typeval,clientval;
$('select.typeval').change(function() {
    //console.log($(this).parents('tr').find('input').val(), $(this).val());
    typeval =  $(this).val();
    clientval = $(this).parents('tr').find('input').val();
});​
  • $(this).parents('tr').find('input').val();//会给你client_id
  • $(this).val();// 会给你选择项的值

然后,您可以将这些值放入您的 AJAX 调用中。

jsFiddle 示例

于 2012-09-07T17:15:17.423 回答
0

使用詹姆斯的解决方案,它看起来像这样:

那么jquery看起来像这样:

var 运动 = this.value var client_id = this.parent().find(".clientval")

于 2012-09-07T17:17:30.240 回答
0

检查这个工作示例.. http://jsfiddle.net/sushanth009/BZ5Wt/

您可以使用此行获取所选行的 ClientId..

var client = $(this).parent().parent().find('.clientval').val();
于 2012-09-07T17:18:10.067 回答
0

那么,您需要执行以下操作:

1.全部删除onchange='changeMovement()',您将不再需要它们。

2.只是echo来自class_idPHP。

3.修正你得到的方式client_id如下。

代码:

$(document).ready(function() {

    $('.typeval').change(function() {
        var movement = $(this).val();
        var client_id = $(this).parent().siblings().find('.clientval').val();
        var class_id = <?php echo $class_id; ?>;

        /* Do your AJAX call here */
    });

});​​​​​​​​​​​​
于 2012-09-07T17:27:45.363 回答
0

使用 php 为您的选择和输入元素提供一个唯一的 id。就像是:

<input type="hidden" id="client_id$client_id" ...

<select name="movement[]" id="mov$client_id" ...

然后在您的 javascript 函数中使用 php 来包含 client_id,如下所示:

changeMovement(client_id)

然后您可以使用 client_id 更改任何对应的移动,如下所示:

var client = $("#client_id"+client_id).val();
var movement = $("#mov"+client_id).val();

对于唯一 ID,您可能希望使用填充每行隐藏输入值字段的任何变量。我在不知道这些数字的确切来源的情况下这么说。

于 2012-09-07T17:01:12.077 回答