当在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验证,因为整个表单被重新绘制。
答案 0 :(得分:1)
我之前也遇到过这个问题。
问题在于.bind('change'),你应该使用.live('change')代替, 在jQuery 1.7中,这可以通过使用同时执行实时绑定和正常绑定的.on()函数来解决。 令人难忘的Yii没有最新的jQuery。对于某些项目,我手动更新了jQuery,但是在中间你必须扩展基类来修复你将获得的jQuery错误。 对于更直接和一次性的解决方案,您可以编写一些js,将元素解除绑定,然后使用.live()函数重新绑定它们。 但至少可以说它有点笨拙。