美好的一天,

我一直在尝试获取所有动态选择框,但它始终返回第一种颜色。

例如,我有一组默认颜色,但是然后单击“添加更多”,它添加了另一组颜色,但是当我将其发布到控制器中时,它总是返回第一种颜色,而忽略了另一组添加的颜色。这是示例图像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新手。请帮助我解决此问题。提前致谢。

最佳答案

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

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);
}
...

关于javascript - 使用Codeigniter中的javascript multifield的动态选择框,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/47828957/

10-10 00:18