我正在为汽车经销商开展一个复杂的项目,我必须根据多个标准创建数据库搜索。数据库中的汽车分为3种类型 - 我们称它们为A,B和C.假设A = 1,B = 2,C = 3的值。该网址看起来像index.php?type_id=1
。到目前为止,工作搜索代码如下。
在index.php
:
<script type="text/javascript">
$(document).ready(function(){
$('#car').on('change',function(){
var carID = $(this).val();
if(carID){
$.ajax({
type:'POST',
url:'ajaxData.php',
data:'marque_id='+carID,
success:function(html){
$('#model').removeAttr("disabled");
$('#model').html(html);
}
});
}else{
$('#model').attr("disabled");
$('#energy').attr("disabled");
}
});
});
</script>
$type_id = $_GET['type_id];
$query = $db->query("SELECT DISTINCT marque_name,a.marque_id FROM vehicule_marque as a INNER JOIN vehicule as b WHERE b.type_id = '$type_id' AND a.marque_id = b.marque_id order by marque_name");
$rowCount = $query->num_rows;
<div>Select car</div>
<select name="car" id="car" required >
<option value="">Select Car</option>
<?php
if($rowCount > 0){
while($row = $query->fetch_assoc()){
echo '<option value="'.$row['marque_id'].'">'.$row['marque_name'].'</option>';
}
}else{
echo '<option value="">Car not available</option>';
}
?>
</select>
<div>Select car model</div>
<select name="model" id="model" disabled>
<option value=""><!--Select car first--></option>
</select>
在ajaxData.php
:
if(isset($_POST["marque_id"]) && !empty($_POST["marque_id"])) {
//Get all state data
$query = $db->query("SELECT DISTINCT a.modele_id, modele_name, a.marque_id FROM vehicule_modele as a INNER JOIN vehicule as b WHERE a.marque_id = ".$_POST['marque_id']." AND b.type_id = '$type_id' AND b.marque_id = a.marque_id AND b.modele_id = a.modele_id ORDER BY modele_name ");
//Count total number of rows
$rowCount = $query->num_rows;
//Display model list
if($rowCount > 0){
echo '<option value="">Select model</option>';
while($row = $query->fetch_assoc()){
echo '<option value="'.$row['modele_id'].'">'.$row['modele_name'].'</option>';
}
}else{
echo '<option value="">Model not available</option>';
}
}
问题在于获取type_id
值并在ajaxData.php
查询中使用它,以便在客户选择汽车品牌后显示模型。在index.php
中,我GET
来自网址的值成功(我尝试回应它并且它有效),但后来我无法让它在其他查询中工作 - 它一直只显示“型号不可用“选项。我尝试将$type_id
内的脚本放入一个新变量中,但这也不起作用。我不确定我错过了什么。如果我删除type_id条件,一切都很完美。如果有人知道如何解决这个问题,我将不胜感激。
答案 0 :(得分:0)
首先,您需要了解对网址index.php?type_id=1
和网址ajaxData.php
的请求是不同的请求,并且知道没有彼此。
因此,如果您尝试访问$_GET['type_id']
中的ajaxData.php
,显然会接收无,因为$_GET
ajaxData.php中排空。如果您向ajaxData.php?type_id=42
发送请求,则将<{strong> 42
作为$_GET['type_id']
。
因此,如果您想在$_GET
中使用某些$_POST
或ajaxData.php
数据,必须明确发送此数据
可以是:
url:'ajaxData.php?type_id=' + yourValue,
// access it with $_GET['type_id']
或
data:'marque_id='+carID+'&type_id='+yourValue,
// access it with $_POST['type_id']