Раскрывающийся список на основе предыдущего раскрывающегося списка с использованием класса php
У меня есть следующий выпадающий на моей странице
<label for="state">State: </label>
<select name="state" class="dropdown">
<option value="" selected>Please Select</option>
<?php echo $states->getStates(); ?>
</select>
Сам ниспадающий список работает и заполняется состояниями без проблем. Но теперь я хочу, чтобы он мог выбирать штат, и в зависимости от этого состояния отображается выпадающий список городов с соответствующими городами этого штата.
Ниже класс, который у меня есть. Я просто не могу понять, как вызвать функцию getCity myclass и передать ей выбранное значение из выпадающего списка состояний.
states.php
class states{
function getStates(){
$success = false;
try{
$con = new PDO( DB_DSN, DB_USERNAME, DB_PASSWORD );
$con->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
$sql = "SELECT DISTINCT(state) FROM tbl_zip ORDER BY state ASC";
$stmt = $con->prepare( $sql );
$stmt->execute();
$valid = $stmt->fetchAll();
if( $valid ) {
$success = true;
$list = "";
// Loop through list of states
foreach($valid as $row) {
$list .= '<option value=\"' . $row["state"] .'\">' . $row["state"] . '</option>';
}
}
$con = null;
return $list;
}catch (PDOException $e) {
echo $e->getMessage();
return $success;
}
}
function getCity($state){
$success = false;
try{
$con = new PDO( DB_DSN, DB_USERNAME, DB_PASSWORD );
$con->setAttribute( PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION );
$sql = "SELECT DISTINCT city FROM tbl_zip WHERE state = :state ORDER BY city ASC";
$stmt = $con->prepare( $sql );
$stmt->bindValue( "state", $state , PDO::PARAM_STR );
$stmt->execute();
$valid = $stmt->fetchAll();
if( $valid ) {
$success = true;
$list = '<select name=\"state\">';
$list .= '<option value=\"\" selected>Please Select</option>';
// Loop through list of states
foreach($valid as $row) {
$list .= '<option value=\"' . $row["city"] .'\">' . $row["city"] . '</option>';
}
$list .= '</select>';
}
$con = null;
return $list;
}catch (PDOException $e) {
echo $e->getMessage();
return $success;
}
}
}
1 ответ
Не уверен, что именно вас беспокоит, но как насчет этого:
$city = $states->getCity($_POST['state']);