我的应用中有一个使用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个小部件。但是当我提交时,只提交了最后一个小部件的结果。
答案 0 :(得分:0)
您可能想要检查您的网络服务器配置。如果您正在使用Apache,则应检查post_max_size
(iirc)