Ajax,PHP,MYSQL交互

时间:2015-06-26 13:39:42

标签: php ajax

我有一个从page1.page1链接的page2发送一个唯一的作业ID到page2.page2有一个ajax代码,如下所示。在这个页面2中,我有一个选择,它接受要调用的申请人数量interview.it根据每个申请人获得的分数从第3页获取这个数字。我如何根据传递的工作ID获取申请人的数据?我认为我的问题是在ajax中传递参数。请帮忙吗? 因此是我的代码但是没有工作。我在第2页得到错误,一个未知的索引jobid。

<?php $getid =$_GET['jobid'];?>
<html>
<head>
    <link href="css/bootstrap.min.css" rel="stylesheet">
<script>
function showSuccess(str,$getid) {

    if (str == "") {
        document.getElementById("txtHint").innerHTML = "";
        return;
    } else {
        if (window.XMLHttpRequest) {
            // code for IE7+, Firefox, Chrome, Opera, Safari
            xmlhttp = new XMLHttpRequest();
        } else {
            // code for IE6, IE5
            xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
        }
        xmlhttp.onreadystatechange = 
        function  () {
            if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
                document.getElementById("txtHint").innerHTML = xmlhttp.responseText;
            }
        }

        xmlhttp.open("POST","interview.php?q="+str);


        xmlhttp.send();
    }
}
</script>
</head>
<body>
  <?php
  echo $getid;
  ?>
<div class="col-md-4 col-md-offset-4">
<form>

    <?php 

     include('includes/conn.php'); 
     $row="SELECT * FROM jobs";  
     $query=mysqli_query($conn,$row) or die(mysqli_error($conn)); 
     while($row=mysqli_fetch_array($query)){
      $ref=$row['id'];
     }          

echo '<select name="names" onchange="showSuccess(this.value'.$getid.')" class="form-control">
  <option value="">Select a person:</option>

  <option value="5">5</option>
  <option value="0">0</option>
  <option value="10">10</option>
  <option value="15">15</option>
  <option value="20">20</option>
  <option value="25">25</option>
  <option value="30">30</option>
  <option value="35">35</option>
  <option value="40">40</option>
  <option value="45">45</option>
  <option value="50">50</option>
  <option value="55">55</option>
  <option value="60">60</option>
  <option value="65">65</option>
  <option value="70">70</option>
  <option value="75">75</option>
  <option value="80">80</option>
  <option value="85">85</option>
  <option value="90">90</option>
  <option value="95">95</option>
  <option value="100">100</option>
  </select>';
  ?>
  <!--<input type="text" class="form-control" name="number" placeholder='Enter the no of candidates' required>-->
</form>
</div>
<br>
<div id="txtHint" class="col-md-4 col-md-offset-4"><b>The candidates</b></div>

</body>
</html>
<?php $q = intval($_GET['q']);
?>
<?php $getid = intval($_POST['$getid']);?>

<?php
include('includes/conn.php');
$row="SELECT  idNo,id,name,jobTitle,SUM(points) AS total FROM shortlist WHERE job='$getid' GROUP BY id ORDER BY total DESC LIMIT $q";
$query=mysqli_query($conn,$row) or die(mysqli_error($conn));

while($row=mysqli_fetch_array($query))
{
  echo $row['name'];
}

mysqli_close($conn);
?>

1 个答案:

答案 0 :(得分:0)

您要发送POST数据

中的值
xmlhttp.open("POST","interview.php?q="+str);

但在您使用的第3个文件中,

<?php $getid = intval($_POST['$getid']);
?>

您没有在POST / GET参数中发送$getid