我需要根据ajax的日期值动态更改下拉列表值。
这是我的代码
<div class="span3">
<label>Bill Date
<div class="span12">
<div class="input-append date" id="dp2" data-date-format="yyyy-mm-dd">
<input class="span6" type="text" readonly="readonly" name='billdate' value="<?php echo $date1; ?>"/> <span class="add-on" disabled><i class="splashy-calendar_day" ></i></span>
</div>
</div>
</label>
</div>
<div class="span2" id="txtHintbill" style=" margin-left:85px;">
<label>Mode:</label>
<select name="mode" class="span10" onChange="billno(this.value)">
<option value="">Select Mode</option>
<option value="CASH" selected>CASH</option>
<option value="CREDIT">CREDIT</option>
<!-- <option value="CHEQUE">CHEQUE</option> -->
</select>
</div>
我的脚本代码是
<script>
function billno(str)
{
var xmlhttp;
if (str=="")
{
document.getElementById("").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("txtHintbill").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","billno.php?q="+str,true);
xmlhttp.send();
}
</script>
我的账单.php文件是
<?php
include"config.php";
$m=$_GET["q"];
?>
<?php
$con=mysql_query("SELECT billno FROM printhub1 WHERE date1='$m' AND cash_detail='Not Received' ORDER BY billno");
$num=mysql_num_rows($con);
if($num==1)
{
?>
<select name="billno" id="billno" >
<?php
while($row=mysql_fetch_array($con))
{
$billno=$row['billno'];
?>
<option value="<?php echo $billno; ?>" <?php echo $billno; ?> ><?php echo $billno; ?></option>
<?php
}
?>
</select>
<?php
}
?>
我会替换选择标签内容。
我已经尝试过检索值并在文本框中显示,但我不知道如何获取完整的下拉列表值。
一些建议...
-
使用 jQUERY 实现 AJAX(既然你已经用 jQuery 标记了帖子,我想知道你为什么不使用它)。这将使您在
billno()
功能下更轻松地完成整个xmlhttp
事情。 -
如果要根据在文本框中输入的日期值动态更改下拉列表,则需要调用日期输入框中的
onChange()
(<input class="span6" type="text" name='billdate'
) - 因为当此输入框中的此值更改时,将触发 AJAX。 行,如下所示:
<option value="<?php echo $billno; ?>" <?php echo $billno; ?> ><?php echo $billno; ?></option>
写下<option value="<?php echo $billno; ?>"><?php echo $billno; ?></option>
-
您需要一种机制来根据 AJAX 调用的回复刷新
<SELECT>
。我建议你使用jQuery来更新<select>
。例$.post ("billno.php", { q : str }, function (data) { $("#txtHintbill").html(数据);});
上面的代码将执行 AJAX 发布,并使用来自服务器的结果更新div ID txtHintbill
的 HTML。
希望这能给你一些前进的方向。