我对 Tapestry 还很陌生,在从选择组件中选择一个值时,我试图更新一个区域。这就是我试图这样做的地方:
<t:Zone t:id="ispTypeZone" id="ispTypeZone">
<t:Select t:id="ispType"
t:blankLabel="[${message:select-label}]" t:zone="ispTypeZone"
t:value="ispType" event="valueChangedFromIspType"
disabled="${editable}" style="width:515px;"
t:blankOption="ALWAYS" t:validate="required"
/>
</t:Zone>
<t:Zone t:id="selectionZone" id="selectionZone">
<t:If t:test="${somethingSelected}">
<t:If test="${ispSelected}">
<t:Zone t:id="ovZone" id="ovZone">
<t:Select t:id="ovType" t:value="ovType"
t:blankLabel="[${message:select-label}]" t:zone="ovZone"
t:validate="required" event="valueChangedFromOvType"
style="width:515px;" />
</t:Zone>
<p:else>
<t:Zone t:id="vpZone" id="vpZone">
<t:Select t:id="vpType" t:value="vpType"
t:blankLabel="[${message:select-label}]" t:zone="vpZone"
t:validate="required" event="valueChangedFromVpType"
t:blankOption="ALWAYS" disabled="${editable}"
style="width:515px;" />
</t:Zone>
</p:else>
</t:If>
<p:else>
</p:else>
</t:If>
</t:Zone>
这就是我所说的渲染:
void onValueChangedFromIspType(String ispType) {
//some code here
if (request.isXHR()) {
ajaxResponseRenderer.addRender(selectionZone);
}
}
无论从选择组件中选择什么值,它都会触发 selectionZone 的渲染,但我不断收到错误消息“无法找到 Ajax Zone 'selectionZone' 进行动态更新”。尽管出现错误消息,“somethingSelected”仍在执行,但未显示以下选择组件。我似乎找不到问题所在,所以如果有人能指出我正确的方向,我将不胜感激。
谢谢。