Mysql
 sql >> Database >  >> RDS >> Mysql

Problema di Jquery onchange in php

Penso che tu stia cercando di ottenere le opzioni da popolare da $mens matrice:

<?php foreach($mens as $row){?>
    <option value="<?php echo $row['gender'] ?>"><?php echo $row['name'] ?></option>
<?php }?>

Se non è questo ciò che intendi, potresti dover chiarire di più.

MODIFICA 1:

Se hai un ampio elenco di elementi da cui attingere, ti consigliamo di utilizzare ajax, ma se il tuo campione è relativamente piccolo, puoi plausibilmente utilizzare semplicemente un array da cui attingere.

DEMO: https://jsfiddle.net/z50m5hnz/ :

<select name="category" id ='category' style="background:transparent">
    <option id ='gender' hidden="hidden">Gender</option>
    <option value="men">Men's</option>
    <option value="girl">Ladies</option>
</select>

<select name="items" id="items">
<select>

<script type="text/javascript">
    var dropdown_items = <?php echo json_encode($mens) ?>;
    $(function () {
        $("#category").change(function () {
            var selectedText = $(this).find("option:selected").text();
            var selectedValue = $(this).val();
            var opts = [];
            $.each(dropdown_items,function(k,v){
                if(selectedValue == 'men' && v.gender == 0) {
                    opts.push('<option name="'+v.gender+'">'+v.name+'</option>');
                }
                else if(selectedValue == 'girl' && v.gender == 1) {
                    opts.push('<option name="'+v.gender+'">'+v.name+'</option>');
                }
            });

            $('#items').html(opts.join(''));
        });
    });
</script>

EDIT 2:

Questa è la mia ultima ipotesi su cosa vuoi, dai commenti penso che forse vuoi ricaricare la pagina ma inviare la selezione del valore:

<script type="text/javascript">
    $(function () {
        $("#category").change(function () {
            var selectedValue = $(this).val();
            window.location =   '?select='+selectedValue;
        });
    });
</script>