0

私は2つのリストボックスを持っています。最初は国用で、もう1つは都市用です。ユーザーが1つの国を選択すると、国に基づいて都市に入力する必要があります

郡のデータベースは( CountryID (pk), Code (pk), Name) city(CountryCode(pk),Name)

ページをロードするreloadと呼ばれるJavaスクリプト関数を作成しますonChangeは正常に機能しますが、都市リストの問題は、国の項目が入力されていません..まだ空です..ここに私のコードがあります. 問題に関連するコードを投稿するだけです。ページが長すぎます。ページのこのコード

dd-check.php

<?php
$cat = $_GET['Country'];
$subcat = $_POST['City'];
?>

CreateAccount.php

<script language=JavaScript>
function reload(form)
{
  var val = form.Country.options[form.Country.options.selectedIndex].value; 
  self.location = 'Create_Account.php?country=' + val ;
}
</script>

<form id="form2" method="post"  enctype="multipart/form-data" action="dd-check.php">
<?php
$Con= mysql_connect("localhost","root",""); 

if(!$Con) 
{ 
  die('Could not connect'.mysql_error());
}

if(!mysql_selectdb("rlounge",$Con))
{
  die(mysql_error());
}

@$cat = $_GET['Country'];

if(strlen($cat) > 0 and !is_numeric($cat))
{  
  echo "Data Error";
  exit;
}

$quer2 = "SELECT *  FROM country";
$result = mysql_query($quer2);
if(isset($cat) and strlen($cat) > 0)
{
  $quer = mysql_query(" SELECT city.`Name` ,  `CountryCode` 
                        FROM  `city` ,  `country` 
                        WHERE  `CountryCode` =  $cat
                        AND  `Code` =  `CountryCode` "); 
}
else
{
  $quer = mysql_query(" SELECT City.name
                      FROM  `city` ,  `country` 
                      WHERE  `Code` =  `CountryCode`"); 
} 
//$cat=$_GET['Country'];
//$subcat=$_POST['City'];
echo "<select name='Country' onchange=\"reload(this.form)\"><option value=''>Select     one</option>";
while($noticia2 = mysql_fetch_array($result)) 
{ 
  if($noticia2['Code'] == $cat)
  {
    echo "<option selected value='$noticia2[Code]'>$noticia2[Name]</option>"."<BR>";
  }
  else
  {
    echo "<option value='$noticia2[Code]'>$noticia2[Name]</option>";
  }
}
echo "</select>";
echo "<select name='City'><option value=''>Select one</option>";
while($noticia = mysql_fetch_array($quer)) 
{ 
  echo  "<option value='$noticia[CountryCode]'>$noticia[Name]</option>";
}
echo "</select>"; 
?>
</form>
4

1 に答える 1

0

このようなhtmlファイルを作成します。

<html>
<head>
<script type="text/javascript">
function getcities(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("result").innerHTML=xmlhttp.responseText;
    }
  }
xmlhttp.open("GET","getcities.php?q="+str,true);
xmlhttp.send();
}
</script>
</head>
<body>

<select name='Countries' onchange='getcities(this)'>
</select>
<p> <span id="result"></span></p>

</body>
</html>

次に、このようにphpファイルを書きます

<?php
$country=$_GET['q'];
get cities from database
while(cities)
{
    echo "<option>".$city."</option>";
}
?>

ここでフィールド country を変更すると、その国名で getcities.php が呼び出されます....getcities.php はスパン要素の「result」に都市を出力します。これは、ページをリロードする必要のない ajax の方法です。

于 2012-04-15T11:49:06.877 に答える