0

嗨,我是 JS 的新手,正在尝试以下方法:

我有一个 Yii 应用程序,其中有一个 ajaxLink 触发了一个幻想框。此链接在幻想框内的 iframe 中呈现视图。渲染视图是一个包含 Yii zii.widgets.jui.CDatePicker 小部件的表单。这将呈现视图并显示具有正确日期值的日期文本字段。但是onclick它不显示日历。

触发fancybox的代码:

echo CHtml::ajaxLink('Add Entry',Yii::app()->createUrl('site/myentry', array('action'=>'new')),
 array('type'=>'GET', 'update'=>'#adexp', 'complete'=>'afterAjax'));

js函数:

function afterAjax()
{
$.fancybox({
    href : '#adexp',
    scrolling : 'no',
    transitionIn : 'fade',
    transitionOut : 'fade', 
width: 1024, 
height: 500,
autoDimensions: false,        
    onClosed: function() { $('#adexp').html(''); location.reload();},
});
}

为表单渲染 iframe:

<iframe src="<?php echo $this->createUrl('site/entryform', array('UtcRecord'=>$model->UtcRecord, 'UserId'=>$model->UserId, 'action'=>$action));?>"  style="width: 100%; height:440px;" id="entryform"></iframe>

以及此表单视图中的小部件:

$this->widget(
        'zii.widgets.jui.CJuiDatePicker',
        array(
        'model'     => $model,
        'attribute' => 'EntryTime',         
        'language'=> 'en',      
        'options'   => array(
            'dateFormat' => 'dd-mm-yy',
            'style'=>'z-index: 5000;',             
        ),
        )
    );

Firebug 的观察:表单中的输入字段没有 Datepicker 类。如果我在普通页面中使用相同的 Yii 小部件代码,则此类存在于输入标签中并且小部件工作正常。

我试过: 1. 将 datepicker 小部件的 z-index 增加到 5000。 2. 在 iframe 头标签中手动包含 jquery 和 css,因为我认为 iframe 可能不会拾取样式和 js。

这可能是 iframe 内的 Yii 小部件渲染问题吗?

非常感谢您对这个问题的任何见解。:-)

4

1 回答 1

0

改变你renderPartial()

$this->renderPartial('path.to.view',$variables_into_view,false,true);

最后一个参数是$processOutput调用CController::processOutput(),它将所需的客户端脚本(在您的情况下为datePickerjs 和 css)插入到输出中。

于 2013-01-07T15:41:48.147 回答