Раскрывающийся список на основе предыдущего раскрывающегося списка с использованием класса 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']);
Другие вопросы по тегам