PHP:两个<select>,第一个是allready fill,第二个是我要填充值</select>

时间:2014-10-28 18:55:21

标签: javascript php mysql ajax codeigniter

我有这个问题:

<fieldset>
<?php
    echo form_open('rssFeedReader/addSource');

    echo '<h2><small>(*) Select in which category you want to add a new Rss Source </small><h2>';

    echo '<div class="form-group">';
        echo '<select class="form-control input-lg" name="category" id="category">';
        foreach( $categories as $row )
        {
            // here i have some values from my database
            echo '<option value="'.$row->id.'">' . $row->category_name . '</option>';
        }
        echo '</select>';
    echo '</div>';

   // NOW, HERE I WANT TO PUT ANOTHER <SELECT>
        echo '<div class="form-group">';
        echo '<select class="form-control input-lg" name="anotherID" id="anotherID">';
        foreach( $array as $r)
        {
            // here i have some values from my database
            echo '<option value="'.$r->something.'">' . $r->something_else. '</option>';
        }
        echo '</select>';
        echo '</div>';



    echo '<div class="form-group">';
        echo form_submit(array('class' => 'btn btn-primary btn-lg btn-block', 'id' => 'remove_source', 'name' => 'remove_source', 'value' => 'Remove Source'));
    echo '</div>';
?>

<?php echo validation_errors('<p class="error">'); ?>

现在,我想做什么。 第二个选择列表最初为空。 我想根据第一个选择列表中选择的值填充它。

我该怎么做?仅在第一个选择列表中选择了某些内容时填充第二个选择列表。

2 个答案:

答案 0 :(得分:1)

MrCode有一个很好的例子。

Using Ajax To Populate A Select Box

<script type="text/javascript" charset="utf-8">
    $(document).ready(function(){
        $('#category').on('change', function (){
            $.getJSON('select.php', function(data){
            var options = '';
            for (var x = 0; x < data.length; x++) {
                options += '<option value="' + data[x]['id'] + '">' + data[x]['name'] + '</option>';
            }
            $('#anotherID').html(options);
        });
    });
});
</script>

你的select.php应该json_encode()你要用

填充你的选择的数据

答案 1 :(得分:0)

处理此问题的最佳方法是在第一个列表上进行更改后填充列表。例如。

$("#category").on("change", function(){
    var selectedValue = $(this).val();
    $.get("some.php?value=" + selectedValue, function(response){
        var options = "";
        for(var i = 0; i < response.length;i++){
            var val = response[i];
            options += "<option value='" + response[i].id + "'>" + response[i].name + "</option>";
        }
        $("#anotherID").empty().append(options);

    });
}

我不得不做出几个假设。例如,你的some.php将采用一个值参数。返回的是json数组[{id:1,name:“option 1”},{id:2,name:“option 2”}]。请记住这一点。