1

我正在将组织列表填充到我网站上的下拉列表中。这个 PHP 很简单,我没有遇到任何问题。

但是,该列表可能会变得非常庞大,我想将列表分成三个按字母顺序排列的部分。(例如 AG、HS、TZ)。如何修改下面的代码以适应使用 AG 对第一个下拉列表进行排序(然后我可以将相同的逻辑应用于其他两个)。

   $sql = pg_query("SELECT name FROM institution ORDER BY name ASC");                                                                 
   while($row = pg_fetch_array($sql)){
      echo "<option value=\"organisation1\">" .$row ['name'] . "</option>";
   }
4

5 回答 5

1

如果最终用户可能知道组织的名称,那么最好使用搜索框和一些 JS 来根据键入的字母填充。

否则,您可能希望有一个额外的初始下拉列表,以按逻辑细分而不是按字母顺序拆分列表(例如国家、城市、部门)

于 2013-02-26T10:56:09.130 回答
0
$sql = pg_query("
    select name
    from institution
    where name < 'H'
    order by name asc
");

$sql = pg_query("
    select name
    from institution
    where name >= 'H' and  name < 'T'
    order by name asc
");

$sql = pg_query("
    select name
    from institution
    where name >= 'T'
    order by name asc
");
于 2013-02-26T11:30:03.817 回答
0

这应该做 AG 和 HS 的把戏

    $AG = $HS = '';
$sql = pg_query("SELECT name FROM institution ORDER BY name ASC");                                                                 
while($row = pg_fetch_array($sql)){
    $char =chr(strtoupper(substr($row ['name'],0,1)));
    if($char<=71){
        $AG .= "<option value=\"organisation1\">" .$row ['name'] . "</option>";
    }
   if(($char>71) && ($char <= 83)){
         $HS .= "<option value=\"organisation1\">" .$row ['name'] . "</option>";
    }
   }
   echo $AG.$HS;

使用 chr 获取第一个字符的 ascii 值。创建条件以将字符串添加到您的小节。你可以在这里查看 ASCII 值:
http ://www.asciitable.com/

于 2013-02-26T10:53:14.180 回答
0
$cityarray = array('axx', 'bxx','txx');

$group1 = array('a','b','c','d','e','f');
$group2  = 'construct array with the require alphapet';
$group3  = 'construct array with the require alphapet';


foreach (cityarray as $city) {
 if (in_array($city[0], group1)) {
   $group1[] = $city 
 } else if (in_array($city[0], group2) {
   $group2[] = $city 
 }  else if (in_array($city[0], group3) {
   $group3[] = $city 
} 

}

//使用上面三个数组来构造下拉

于 2013-02-26T10:59:09.737 回答
0

我不是 php 或 postgresql 人,但你需要的是一个简单的编程逻辑。简单的算法就足够了。

step1. run a loop through the array to fill dropdowns.

step2. place appropriate conditions inside the loop to fill all the three dropdowns appropriately.

看到这个代码。支持算法。您可能需要根据您的语言对其进行微调

 $sql = pg_query("SELECT name FROM institution ORDER BY name ASC");

   $ddlClass='.dropdown1';                                                                 

   while($row = pg_fetch_array($sql)){
         $char = chr(strtoupper(substr($row ['name'],0,1)));

         if($char>=65 && $char<=71);
            $ddlClass=  '.dropdown1';

         else if($char>=72 && $char<=83);
           $ddlClass=  '.dropdown2';

         else if ($char>=83 && $char <=90)
            $ddlClass=  '.dropdown3';
         $($ddlClass).append("<option value=\"organisation1\">" .$row ['name'] . "</option>");
 }

我使用 jquery 来创建您的下拉列表,您可以使用其他任何东西,即 javascript、php 来执行此操作。

于 2013-02-26T11:09:18.830 回答