使用Codeigniter中的javascript multifield动态选择框

时间:2017-12-15 09:04:31

标签: javascript php jquery codeigniter

美好的一天,

我一直试图获取所有动态选择框,但它总是返回第一种颜色。

例如我有一组默认颜色,但是我点击添加更多它添加另一组颜色但是当我在控制器中发布它时它总是返回第一种颜色并忽略另一组添加的颜色。这是示例图片set of color

有人可以帮我这个吗?我现在已经被困了4天了。

这是我的观看代码:

<div class="form-content">
    <div class="row">
        <div class="col-md-12">
            <p><button type="button" id="btnAdd" class="btn btn-primary">Add Color</button></p>
            <br/>
        </div>
    </div>
    <div class="row group">
        <div class="col-md-5">
            <div class="form-group">
                <label></label>
                <select name="color1[]" id="color1" class="form-control" >
                <option value="" > Color 1</option>

                <?php foreach($colors as $color): ?>
                 <option value="<?php echo $color['colorID']; ?>">
                  <?php echo $color['colorDesc']; ?>
                  </option>
                <?php endforeach; ?> 
              </select>
            </div>
        </div>
        <div class="col-md-5">
            <div class="form-group">
                <label></label>
                <select name="color2[]" id="color2" class="form-control" >
                <option value="" > Color 2</option>

                <?php foreach($colors as $color): ?>
                 <option value="<?php echo $color['colorID']; ?>">
                  <?php echo $color['colorDesc']; ?>
                  </option>
                <?php endforeach; ?> 
              </select>
            </div>
        </div>
        <div class="col-md-2">
            <div class="form-group">
                <button type="button" class="btn btn-danger btnRemove">X</button>
            </div>
        </div>
    </div>
</div>

这是脚本

<script type="text/javascript">
    $(".form-content").multifield({
        section: ".group",
        btnAdd:"#btnAdd",
        btnRemove:".btnRemove",
    });
</script>

这是我的控制器

$color1 = $this->input->post('color1');
$color2 = $this->input->post('color2');

for($i = 0; $i < count($color1); ++$i) {
     echo $make = $color1[$i];

}

我刚刚开始使用Codeigniter新手。请帮我解决这个问题。提前谢谢。

1 个答案:

答案 0 :(得分:0)

试试这个(我没有测试过):

HTML:

<div class="form-content">
    <div class="row">
        <div class="col-md-12">
            <p>
                <button type="button" id="btnAdd" class="btn btn-primary">Add Color</button>
            </p>
            <br/>
        </div>
    </div>
    <?php $count=0 ; if($this->input->post('color1')) $count = count($this->input->post('color1')); for($i=0;$i<$count,$i++):?>
        <div class="row group">
            <div class="col-md-5">
                <div class="form-group">
                    <label></label>
                    <select name="color1[<?php echo $i;?>]" id="color1" class="form-control" <?php set_select( 'color1['.$i. ']',$color[ 'colorID']);?>>
                        <option value=""> Color 1</option>
                        <?php foreach($colors as $color): ?>
                        <option value="<?php echo $color['colorID']; ?>">
                            <?php echo $color[ 'colorDesc']; ?>
                        </option>
                        <?php endforeach; ?>
                    </select>
                </div>
            </div>
            <div class="col-md-5">
                <div class="form-group">
                    <label></label>
                    <select name="color2[<?php echo $i;?>]" id="color2" class="form-control">
                        <option value=""> Color 2</option>
                        <?php foreach($colors as $color): ?>
                        <option value="<?php echo $color['colorID']; ?>" <?php set_select( 'color2['.$i. ']',$color[ 'colorID']);?>>
                            <?php echo $color[ 'colorDesc']; ?>
                        </option>
                        <?php endforeach; ?>
                    </select>
                </div>
            </div>
            <div class="col-md-2">
                <div class="form-group">
                    <button type="button" class="btn btn-danger btnRemove">X</button>
                </div>
            </div>
        </div>
        <?php endfor;?>
</div>
控制器中的

(您还可以添加验证):

...
if($this->input->post('color1')) {
    $result = array();
    $count = count($this->input->post('color1'));
    for($i=0;$i<$count;$i++) {
        if($this->input->post('color1['.$i.']') && $this->input->post('color2['.$i.']')) {
            $result[$i] = ['color1'=>$this->input->post('color1['.$i.']'),'color2'=>$this->input->post('color2['.$i.']')];
        }
    }
    print_r($result);
}
...