繁体   English   中英

无法将ajax变量传递给php

[英]Cant pass ajax variable to php

我有这个html代码,说Cliente的部分充满了简单的mysql查询; 我想做的是,当您在Cliente中选择一个选项时,它会自动在第二个列表中显示链接到数据库中cliente的选项。

<div class="form-group">
  <label class="col-md-4 control-label" for="selectbasic">Cliente</label>
  <div class="col-md-4">
    <select id="cliented" name="cliented" class="form-control">
      <?php foreach ($dcli3 as $key) { ?>
        <option value="<?php echo $key['id'] ?>"><?php echo $key['nombre'] . ' ' . $key['apellido'] ?></option>
      <?php } ?>
    </select>
  </div>
</div>

<div class="form-group">
  <label class="col-md-4 control-label" for="selectbasic">Cuenta</label>
  <div class="col-md-4">
    <select id="cuentad" name="cuentad" class="form-control">
      <?php foreach ($dcu as $key) { ?>
        <option value="<?php echo $key['numero'] ?>"><?php echo $key['numero'] ?></option>
      <?php } ?>
    </select>
  </div>
</div>

为了获得第一个列表中的选定选项,我可以使用以下js代码进行操作:

    $(document).ready(function() {
    $('select[name="cliented"]').change(function(){
        var cliented = $(this).val();
        $.ajax({
                type: 'POST',
                url: 'cons.php',
                data: cliented,
                dataType: 'json',
         });
    });
});

到那时为止,一切都很好,即使我使用alert(cliented); 它显示了与所选客户端相对应的ID。 问题是当我这样查询时:

if (isset($_POST['cliented'])) {
$cliente = $_POST['cliented'];
$cu = "SELECT * FROM cuenta WHERE idc= '$cliente'";
$dcu = $conn->query($cu);
}

$ cliente变量始终为空。 我想念什么?

您要发送键/值对。 现在,您所发送的就是价值

更改:

 data: cliented,

至:

 data: {cliented: cliented},

您需要将值分配给键。

$(document).ready(function () {
    $('select[name="cliented"]').change(function () {
        var cliented = $(this).val();
        var postData = {
            cliented: cliented
        }
        $.ajax({
            type: 'POST',
            url: 'cons.php',
            data: postData,
            dataType: 'json',
        });
        return false;
    });
});
$(document).ready(function() {
$('select[name="cliented"]').change(function(){
    var cliented = $(this).val();

    DATA = 'cliented=' + cliented;

    $.ajax({
            type: 'POST',
            url: 'cons.php',
            data: cliented,
            dataType: 'json',
                 success:function()  
                 {

                 }
     });
});
});

您没有使用ajax设置变量名称。

更改:

data: cliented,
to:
data:'cliented='+cliented 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM