POST方法发布部分数据

时间:2014-04-25 10:56:23

标签: php jquery ajax yii

我的应用中有一个使用ajax进行更新的表单。我最初有3个下拉列表但是在ajax呼叫号码增加之后。这是我的表格

<?php $form=$this->beginWidget('bootstrap.widgets.TbActiveForm',array(
    'id'=>'schedule-form',
    'enableAjaxValidation'=>false,
)); ?>

    <p class="help-block">Fields with <span class="required">*</span> are required.</p>

    <?php echo $form->errorSummary($model); ?>
        <?php echo $form->dropDownListRow($model,'class_id',$classes); ?>

       <?php echo $form->dropDownListRow($model,'day_id',$days,array('selected'=>$i)); ?>
        <?php echo $form->dropDownListRow($model,'teacher_id',$days); ?>
        <?php echo CHtml::textField('', '',array('id'=>'search-field')); ?>




    <div  id="copy1">



    </div>

    <div class="form-actions">
        <?php $this->widget('bootstrap.widgets.TbButton', array(
            'buttonType'=>'submit',
            'type'=>'primary',
            'label'=>$model->isNewRecord ? 'Create' : 'Save',
        )); ?>
    </div>

<?php  $this->endWidget(); ?>
        <?php $url=Ccontroller::createUrl('schedule/ajaxSchedule');  Yii::app()->clientScript->registerScript('search', "
$('#search-field').keyup(function(){
$.ajax(
        {
        url:'".$url."',
        data:{ajaxdata:$(this).val()},
        success:function(data){
        $('#copy1').empty();
        $('#copy1').html(data);
        },

        }
        );
});
");
?>

当我输入inm文本字段时,它会进行ajax调用。 Ajax调用是完美的,并返回所需的数据。在我返回的数据中,我有一些重复的小部件。他们在那里显示没有问题。但是当我提交表单时,我只得到最后一个小部件的结果。即使是初始dropDowns也没有发布,我的意思是他们的结果没有发布。我做错了什么?
这是我的ajax重新调整的代码。

<?php

for($i=0;$i<$numberOfperiods;$i++ ){
?>
 <div class="row copy">
       <?php echo CHtml::dropDownList('Schedule','subject_id[]',$courses,array('id'=>'subject_is'.$i)); ?>
       <?php $config1=array('model' => $model,
                   'attribute'=>'start_time[]','htmlOptions'=>array('id'=>'start_time'.$i));
       $this->widget(
               'bootstrap.widgets.TbTimePicker', $config1
       );
       ?>
         <?php $config=array('model' => $model,
                   'attribute'=>'end_time[]','htmlOptions'=>array('id'=>'end_time'.$i));
       $this->widget(
               'bootstrap.widgets.TbTimePicker', $config
       );
       ?>


    </div>

<?php } ?>

循环效果很好。假设我有numberOfperiods = 6,那么将显示6个小部件。但是当我提交时,只提交了最后一个小部件的结果。

1 个答案:

答案 0 :(得分:0)

您可能想要检查您的网络服务器配置。如果您正在使用Apache,则应检查post_max_size(iirc)