我有一个表单,其中一部分具有用于添加新行的ajax函数的里程碑表格输入。
这是ajax调用的函数:
public function actionNewMilestoneRow($index)
{
$milestoneModel = new TgifMilestone;
$this->renderPartial('_milestone', array(
'milestoneModel' => $milestoneModel,
'i' => $index,
),false,true);
}
这是视图的表部分,JS用于添加额外的行:
<table class="timeline">
<tbody class="milestones">
<tr><th>Milestone</th><th>Expected<br />Completion Date</th></th></tr>
<?php foreach ($milestoneModels as $i=>$milestoneModel): ?>
<tr>
<td><?php echo $form->textField($milestoneModel,"[$i]milestone",array('size'=>75,'maxlength'=>250)); ?>
<?php echo $form->error($milestoneModel,"[$i]milestone]"); ?>
</td>
<td>
<?php
$date_value=empty($milestoneModel->expected_completion_date)?date('l, M j, Y'):$milestoneModel->expected_completion_date;
$this->widget('zii.widgets.jui.CJuiDatePicker',array(
'model'=>$milestoneModel, //Model object
'language'=>'',
'attribute'=>"[$i]expected_completion_date", //attribute name
'options'=>array(
'dateFormat' => 'DD, M d, yy',// equivalent to PHP date 'l, M j, Y'
'defaultDate'=>$date_value,//see above
), // jquery plugin options
));
?>
<?php echo $form->error($milestoneModel,"[$i]expected_completion_date"); ?>
</td>
</tr> <?php endforeach; ?>
</tbody>
</table>
<?php echo CHtml::button('Add Another Milestone', array('class' => 'milestone-add')) ?>
<script>
$(".milestone-add").click(function(){
$.ajax({
success: function(html){
$(".milestones").append(html);
},
type: 'get',
url: '<?php echo $this->createUrl('newMilestoneRow');?>',
data: {
index: $(".milestones tr").size() - 1
},
cache: false,
dataType: 'html'
});
});
</script>
如果我在没有返回和processoutput的情况下渲染部分,那么对于添加的行,一切正常:
$this->renderPartial('_milestone', array(
'milestoneModel' => $milestoneModel,
'i' => $index,
));
除了日期选择器没有显示,但表格正确呈现。
当我添加return和process输出时,我得到了datepicker,但它打破了表:
$this->renderPartial('_milestone', array(
'milestoneModel' => $milestoneModel,
'i' => $index,
),false,true);
表格行和表格单元格标签消失:
<tr><!-- this is the row befoe the added row -->
<td><input id="TgifMilestone_4_milestone" type="text" name="TgifMilestone[4][milestone]" maxlength="250" size="75"></td>
<td><input id="TgifMilestone_4_expected_completion_date" class="hasDatepicker" type="text" name="TgifMilestone[4][expected_completion_date]"></td>
</tr>
<link href="/requests/assets/f73aa0bb/jui/css/base/jquery-ui.css" type="text/css" rel="stylesheet">
<input id="TgifMilestone_5_milestone" type="text" name="TgifMilestone[5][milestone]" maxlength="250" size="75">
<input id="TgifMilestone_5_expected_completion_date" class="hasDatepicker" type="text" name="TgifMilestone[5][expected_completion_date]">
</tbody>
</table>
没有返回和进程输出,它呈现如下:
<tr>
<td><input id="TgifMilestone_5_milestone" type="text" name="TgifMilestone[5][milestone]" maxlength="250" size="75"></td>
<td><input id="TgifMilestone_5_expected_completion_date" type="text" name="TgifMilestone[5][expected_completion_date]"></td>
</tr>
</tbody>
</table>
任何想法如何解决它所以我得到表行和添加行的日期选择器?
在bool.dev的请求中添加_milestone.php局部视图;
<tr>
<td><?php echo CHtml::activeTextField($milestoneModel,"[$i]milestone",array('size'=>75,'maxlength'=>250)); ?></td>
<td>
<?php
$date_value=empty($milestoneModel->expected_completion_date)?date('l, M j, Y'):substr($milestoneModel->expected_completion_date,0,10);//default date must be a date not a datetime
$this->widget('zii.widgets.jui.CJuiDatePicker',array(
'model'=>$milestoneModel, //Model object
'language'=>'',
'attribute'=>"[$i]expected_completion_date", //attribute name
'options'=>array(
'dateFormat' => 'DD, M d, yy',// equivalent to PHP date 'l, M j, Y'
'defaultDate'=>$date_value,//see above, date not datetime..
), // jquery plugin options
));
?>
</td>
</tr>
答案 0 :(得分:1)
这里的问题是processOutput
正在加载 jquery.js , jquery-ui.min.js 和 jquery-ui.css 再次导致错误的元素。即使CJuiDatePicker
需要这些文件,加载它们一次(在第一次渲染期间)就足够了,在随后的ajax调用中,我们可以避免再次加载它们。
为此,您只需修改 _milestone.php 部分视图文件:
<?php
Yii::app()->clientScript->scriptMap['jquery.js']=false;
Yii::app()->clientScript->scriptMap['jquery-ui.css']=false;
Yii::app()->clientScript->scriptMap['jquery-ui.min.js']=false;
?>
<!-- rest of your _milestone.php -->
当processOutput
遇到上述3个文件的registerScript调用时,它只会被忽略,但CJuiDatePicker
所需的其余脚本(如激活)将会被忽略。包含在剧本中。