duandeng2265 2017-02-23 10:11
浏览 51
已采纳

来自数据库的onchange下拉列表 - php,没有java或ajax

I have a problem, I want to display all rows from database to dynamic onchange select form, but it displays only first or only last row. Could you please help me someone?

this is my code:

<?php
   $selected11 = '';
   function get_options11($vyber11) {   
      $queryyy = mysql_query("SELECT funkcia, ID_funk FROM funkcie");
      while($row = mysql_fetch_array($queryyy)) {
         $v11=$row['ID_funk'];
         $k11=$row['funkcia'];
         $moznosti11 = '';
         if($vyber11==$v11){
            $moznosti11.='<option value="'.$v11.'" selected>'.$k11.'</option>';
         } else{
            $moznosti11.='<option value="'.$v11.'">'.$k11.'</option>';}
         }
        return $moznosti11;
     }
     if(isset($_POST['funkcia'])) {
        $selected11 = $_POST['funkcia'];
     }
   }
?> 
<select name="funkcia" class="ramceky" style="width: 150px; height: 40px" onchange="this.form.submit();">
   <option><?php echo get_options11($selected11); ?></option> 
</select>
  • 写回答

2条回答 默认 最新

  • doufa5001 2017-02-23 10:36
    关注

    You are assigning the variable $moznosti11; in every loop. Move it right before while loop and it should work like charm.

    See here:

    $moznosti11 = '';
    while($row = mysql_fetch_array($queryyy)) {
         $v11=$row['ID_funk'];
         $k11=$row['funkcia'];
    
         if($vyber11==$v11){
            $moznosti11.='<option value="'.$v11.'" selected>'.$k11.'</option>';
         } else{
            $moznosti11.='<option value="'.$v11.'">'.$k11.'</option>';}
         }
        return $moznosti11;
     }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 Qt下使用tcp获取数据的详细操作
  • ¥15 idea右下角设置编码是灰色的
  • ¥15 全志H618ROM新增分区
  • ¥15 在grasshopper里DrawViewportWires更改预览后,禁用电池仍然显示
  • ¥15 NAO机器人的录音程序保存问题
  • ¥15 C#读写EXCEL文件,不同编译
  • ¥15 MapReduce结果输出到HBase,一直连接不上MySQL
  • ¥15 扩散模型sd.webui使用时报错“Nonetype”
  • ¥15 stm32流水灯+呼吸灯+外部中断按键
  • ¥15 将二维数组,按照假设的规定,如0/1/0 == "4",把对应列位置写成一个字符并打印输出该字符