当用户选择单个值时显示数据库中的数据


Displaying data from the database when user selects single value

当用户选择下拉值时,我试图显示数据库中的数据。有一个下拉列表显示所有的注册会员。当管理员用户从下拉菜单中选择注册的成员名时,它必须填充该成员的所有详细信息。

我的选择框代码是这样的

if ($_SESSION['admin_privs'] == "yes" || $_SESSION['edit_all_listings'] == "yes") {
                    $display .= '<tr><td align="right"><strong>' . $lang['listing_editor_listing_agent'] . ':</strong></td>';
                    $display .= '<td align="left" class="row_main">';
                    $agent_select = array();                    
                    // find the name of the agent listed as ID in $edit_or_owner
                    $sql = "SELECT userdb_user_first_name, userdb_user_last_name FROM " . $config['table_prefix'] . "userdb WHERE (userdb_id = $_SESSION[userID])";
                    $ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;
                    $recordSet = $conn->Execute($sql);
                    if ($recordSet === false) {
                        $misc->log_error($sql);
                    }
                    // strip slashes so input appears correctly
                    $agent_first_name = $misc->make_db_unsafe($recordSet->fields['userdb_user_first_name']);
                    $agent_last_name = $misc->make_db_unsafe($recordSet->fields['userdb_user_last_name']);
                    if ($_SESSION['admin_privs'] != "yes")
                    {
                        $agent_select[$_SESSION['userID']] = $agent_last_name.','.$agent_first_name;
                    }
                    // fill list with names of all agents
                    $sql = "SELECT userdb_id, userdb_user_first_name, userdb_user_last_name FROM " . $config['table_prefix'] . "userdb where userdb_is_agent = 'yes' or userdb_is_admin = 'yes' ORDER BY userdb_user_last_name,userdb_user_first_name";
                    $ADODB_FETCH_MODE = ADODB_FETCH_ASSOC;
                    $recordSet = $conn->Execute($sql);
                    if ($recordSet === false) {
                        $misc->log_error($sql);
                    }
                    while (!$recordSet->EOF) {
                        // strip slashes so input appears correctly
                        $agent_ID = $recordSet->fields['userdb_id'];
                        $agent_first_name = $misc->make_db_unsafe($recordSet->fields['userdb_user_first_name']);
                        $agent_last_name = $misc->make_db_unsafe($recordSet->fields['userdb_user_last_name']);
                        if ($agent_ID == $_SESSION['userID']) {
                            $agent_select[$agent_ID] = $agent_last_name.','.$agent_first_name;
                            $selected = $agent_ID;
                        }else {
                            $agent_select[$agent_ID] = $agent_last_name.','.$agent_first_name;
                        }
                        $recordSet->MoveNext();
                    }
                    $display .= $form->selectBox($agent_select, $selected, 'or_owner');
                    $display .= "</td>";
                    $display .= '</tr>';
                }

对于表单我有不同的功能,像这样

function selectBox($array, $selected='', $name='', $size=1, $multiple=false, $additional='') { 
    $res = ''; 
    static $count = 0; 
    if (is_array($array)) { 
        if ($name == '') { 
            $name = 'selectBox' . ++$count; 
        }
        $res .= "<select name='"$name'" size='"$size'"" . ($multiple==false ? '' : " multiple='"multiple'"") . ($additional ? " $additional" : '') . ">'n"; 
        $i = 0; 
        foreach($array as $key => $value) { 
            $res .= "<option value='"$key'"" . ($key == $selected ? " selected='"selected'"" : '') . ">$value</option>'n"; 
        } 
        $res .="</select>'n"; 
    }

    return $res; 
} 

    function textField($value, $name='', $hidden=false, $size =-1, $length =-1, $additional='') { 
        $res = ''; 
        static $count = 0; 
        if ($name == '') { 
            $name = 'textField' . ++$count; 
        } 
        $res .= "<input name='"$name'" type='"" . ($hidden ? 'password' : 'text') . "'" value='"$value'""; 
        $res .= ($size != -1 ? " size='"$size'"" : ''); 
        $res .= ($length != -1 ? " maxlength='"$length'"" : ''); 
        $res .=  ($additional ? " $additional" : '') . ">"; 
        return $res; 
    } 

现在我想从数据库中显示所选用户的详细信息,有人能告诉我如何实现这一点吗?由于

我不是来自php,但在查看您的代码后,它看起来像您的会话导致这个问题,尝试从会话点调试。

使用AJAX可以最好地实现这一点。在w3schools.com上有一个教程,解释了ajax是如何工作的。你只需要修改他们提供的代码。

基本上,你需要的是:

<SELECT name='name' id='123' onchange='userhint(this.value)'><OPTION value='usercode'...

由您选择。关键是把onchange调用放在SELECT中。

你还需要一个form goes here

JS看起来像:

function userhint(str)
{
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("changingdiv").innerHTML=xmlhttp.responseText;
    }
  }
xmlhttp.open("GET","myphpfile.php?q="+str,true);
xmlhttp.send();
}

这将把'changingdiv'的内容替换为myphpfile.php在响应q的get请求时返回的内容。你显然可以自己编写这个文件。

根据您想要的方式,php可以创建新div的完整HTML或返回一个json字符串,然后您可以使用它来填充原始区域。对于初学者来说,第一个选项绝对是最简单的(也是上面非常基本的js所期望的),但是json方法将使用相当少的带宽,并且更容易重用同一个文件来提供多个页面。