根据我使用 ajax 选择的日期从数据库中获取下拉列表值


Get Dropdown list value from database based on date i picked using ajax

我需要根据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
}
?>

我会替换选择标签内容。

我已经尝试过检索值并在文本框中显示,但我不知道如何获取完整的下拉列表值。

一些建议...

  1. 使用 jQUERY 实现 AJAX(既然你已经用 jQuery 标记了帖子,我想知道你为什么不使用它)。这将使您在billno()功能下更轻松地完成整个xmlhttp事情。

  2. 如果要根据在文本框中输入的日期值动态更改下拉列表,则需要调用日期输入框中的onChange()<input class="span6" type="text" name='billdate' ) - 因为当此输入框中的此值更改时,将触发 AJAX。

  3. <option value="<?php echo $billno; ?>" <?php echo $billno; ?> ><?php echo $billno; ?></option>写下
  4. 行,如下所示:

<option value="<?php echo $billno; ?>"><?php echo $billno; ?></option>

  1. 您需要一种机制来根据 AJAX 调用的回复刷新<SELECT>。我建议你使用jQuery来更新<select>。例

    $.post ("billno.php", { q : str }, function (data) { $("#txtHintbill").html(数据);});

上面的代码将执行 AJAX 发布,并使用来自服务器的结果更新div ID txtHintbill的 HTML。

希望这能给你一些前进的方向。