代码点火器 - 根据另一个选择标签值选择标签选项

时间:2016-10-12 09:32:47

标签: php jquery ajax codeigniter frameworks

我是CodeIgniter的新手,还是初级编程人员,所以不要生我的气。

PS:我的英语也不要生气。 ;)

我正在为一个项目创建小型CMS。在该项目中,它的几个选择标签,第一个只有几个值,但是下一个,有很多值,这取决于我之前提到的select标签中的一个值。

我的数据库表依赖项等等一切正常,但我不知道如何使依赖项显示在select标签中。我尝试用Ajax制作它,但我仍然没有制作它,我读到我可以用codeIgniter库制作它,是真的吗?任何人都可以帮助我吗?

这是我的观看文件:

    <?php echo validation_errors('<p class="alert alert-dismissable alert-danger">'); ?>
<form method="post" action="<?php echo base_url(); ?>admin/engines/add">
    <div class="row">
        <div class="col-lg-6">
            <h1>Engine Type</h1>
        </div>
        <div class="col-lg-6">
            <div class="btn-group pull-right">
                <input type="submit" name="submit" class="btn btn-success" value="Save">
                <a href="<?php echo base_url(); ?>admin/engines" class="btn btn-default">Close</a>
            </div>
        </div>
    </div><!-- /.row -->
    <div class="row">
        <div class="col-lg-12">
            <ol class="breadcrumb">
                <li><a href="<?php echo base_url(); ?>admin/dashboard"><i class="fa fa-dashboard"></i>Dashboard</a></li>
                <li><a href="<?php echo base_url(); ?>admin/dashboard"><i class="fa fa-pencil"></i>Variklio Tipai</a></li>
                <li class="active"><i class="fa fa-plus-square-o"></i>Pridėti Variklio tipą</li>
            </ol>
        </div>
    </div>
    <div class="row">
        <div class="col-lg-12">
            <h2>Engine type One</h2>
            <div class="form-group">
                <label>Engine Name</label>

                <input class="form-control" type="text" name="engine" value="<?php echo set_value('engine'); ?>" placeholder="Engine Type" >
            </div>

            <div class="form-group">
                <label>Category</label>
                <select name="brand" class="form-control">
                    <option value="category">Choose category</option>
                    <?php foreach($categories as $category) : ?>
                        <option value="<?php echo $category->id; ?>"><?php echo $category->category_name; ?></option>
                    <?php endforeach; ?>
                </select>
            </div>
        <!-- END Category-->
        <!-- *** Brand *** -->
            <div class="form-group">
                <label>Brand</label>
                <select name="brand" class="form-control">
                    <option value="">Choose Brand</option>
                    <?php foreach ($brands as $brand) : ?>
                        <option value="<?php echo $brand->id; ?>"><?php echo $brand->v_brand_name; ?></option>
                    <?php endforeach; ?>
                </select>
            </div>
        <!-- **** END Brand ***-->
        <!-- *** Model *** -->
            <div class="form-group">
                <label>Model</label>
                <select name="model" class="form-control">
                    <option value="">Choose model</option>
                    <?php foreach ($models as $model) : ?>
                        <option value="<?php echo $model->id; ?>"><?php echo $model->v_model_name; ?></option>
                    <?php endforeach; ?>
                </select>
            </div>
        <!-- **** END MODEL ***-->
            </div>

        </div>


    </div>
</form>

1 个答案:

答案 0 :(得分:1)

例如这是我的观点

<select name='list1' id='list1'>
    <option value='1'>id 1</option>
    <option value='2'>id 2</option>
    <option value='3'>id 3</option>
    <option value='4'>id 4</option>
    <option value='5'>id 5</option>
</select>

这是第二个下拉列表

<select name='list2' id='list2'>

</select> 

现在jquery代码是

$("#list1").on("change",function(){
    var value = $(this).val();
    $.ajax({
         url : "example.com/welcome/get_data",
         type: "post",
         data: {"value":value},
         success : function(data){
             $("#list2").html(data);
         },
    });
});

现在我的控制器功能是

 public function get_data()
 {
      $value = $this->input->post("value");
      $data = $this->mymodal->get_data($value);
      $option ="";
      foreach($data as $d)
      {
         $option .= "<option value='".$d->id."' >".$d->name."</option>";
      }
       echo $option;
 }

我的模型功能是

 public function get_data($value)
 {
    $this->db->where("id",$value);
    return $this->db->get("table_name")->result();
 }