如何使用yii以持久方式显示基于下拉列表的动态代码?

时间:2012-12-19 01:08:25

标签: jquery ajax yii

当在yii中更改下拉列表时,我会渲染一些表单元素,如下所示:

$form->dropdownListRow($model, 'type', array('item1','item2','etc') ,
    array('ajax'=>array(
        'type'=>'POST',
        'url'=>CController::createUrl('ProfileFieldRule/showAttributes'),
        'update'=>'#showAttributes',                        
    ))
));

ProfileFieldRule / showAttributes使用CHtml渲染表单元素,这导致了我的第一个问题 - 我必须使用opentag等,并重复在表单中完成的工作。

echo CHtml::openTag('div', array('class' => 'control-group '));
echo CHtml::activeLabel($attr, $name, array('class' => 'control-label'));
etc

第二个问题是:如果没有更改事件(例如提交的表单有错误),则不会加载动态内容。

我正在传递模型并检查它是否为null,否则执行与ProfileFieldRule / showAttributes相同的渲染,例如:

   <div id="showAttributes">
    <?php if (isset($attr)) {
        //do the same rendering as in showAttributes
        $vars = get_class_vars(get_class($attr));
             foreach ($vars as $name => $value) {
                 //etc...
    ?>
    </div>

如果我可以调用上面的代码onload,onchange,并且仍然可以访问$ form,那将是理想

我对任何事情持开放态度,那么如上所述显示和保持动态内容的最佳(或好)解决方案是什么?

提前感谢任何建议。

修改

这是一张正在发生的事情的图像http://imgur.com/cZjRZ 注意,渲染的元素没有显示ajax验证(以红色/绿色突出显示),因为我对ajax很糟糕并且仍在计算

我应该注意,我考虑过的另一个解决方案是摆脱showAttributes,继续将两个模型传递给表单,并在更改时再次调用create action。然而,当下拉列表被更改时,这会删除之前的ajax验证,因为整个表单被重新绘制。

1 个答案:

答案 0 :(得分:1)

我之前也遇到过这个问题。

问题在于.bind('change'),你应该使用.live('change')代替, 在jQuery 1.7中,这可以通过使用同时执行实时绑定和正常绑定的.on()函数来解决。 令人难忘的Yii没有最新的jQuery。对于某些项目,我手动更新了jQuery,但是在中间你必须扩展基类来修复你将获得的jQuery错误。 对于更直接和一次性的解决方案,您可以编写一些js,将元素解除绑定,然后使用.live()函数重新绑定它们。 但至少可以说它有点笨拙。