不能让ajax在页面中显示,但可以在谷歌元素检查器中看到

时间:2014-07-23 00:09:47

标签: javascript php jquery mysql ajax

我正在制作一个简单的发票页面。我从mysql填充一个下拉框,当我检查项目时,我希望描述框预先填充。但它不工作....我可以在网络检查器上看到它并预览它。我的代码如下htmlinputform,php,ajaxget

<div class="row">

<div class="col-md-2">
<select type="text" name='idd' id="inputItem" placeholder="Item #1" class="form-control" onblur="showUser(this.value)">
<option></option>
<?php

require ('dbconnect.php');
$result = $con->query("select id, item from items");

while ($row = $result->fetch_assoc()) {

unset($id, $name);
$id = $row['id'];
$name = $row['item']; 
echo '<option value="'.$id.'">'.$name.'</option>';

    }
echo "</select>";
mysqli_close($con);
?> 

</div>
<div class="col-md-6">
<input type="text" id="description1" placeholder="Description" class="form-control" onchange="1description()"></div>
<div class="col-md-1">
<input type="text" id="qty1" placeholder="Qty." class="form-control"></div>
<div class="col-md-1">
<input type="text" id="tax1" placeholder="Tax" class="form-control"></div>
<div class="col-md-2">
<input type="text" id="itemprice1" placeholder="Item Total" class="form-control" onchange="myFunction()" onblur="myFunction1()"></div>
</div>

PHP

<?php
$q = intval($_GET['q']);                                                    
require ('dbconnect.php');
mysqli_select_db($con,"items");
$sql="SELECT description FROM items WHERE id = '".$q."'";
$result = mysqli_query($con,$sql);



while($row = mysqli_fetch_array($result)) {


echo $row['description'];

}


mysqli_close($con);
?>

AJAX

<script>
function showUser(str) {
if (str=="") {
document.getElementById("description1").innerHTML="";
return;
} 
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("description1").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","getuser.php?q="+str,true);
xmlhttp.send();
}
</script>

1 个答案:

答案 0 :(得分:1)

使用.value代替innerHTMLinnerHTML不用于输入字段。

document.getElementById("description1").value =xmlhttp.responseText