2012-08-01 62 views
0

我有2个单选按钮组。这两个按钮是radioGroupLoanType和radioGroupLoanType。加载选项后设置单选按钮组的值?

radioGroupLoanType的选项将根据radioGroupLoanType中的选项而改变。这很好。

如果只有一个选项,那么radioGroupLoanType的click事件设置radioGroupLoanType的值。似乎正在发生的事情是,只有每隔一次点击才能确定价值。如果我在选择上点击两次,则设置适当的值。

我怀疑发生了什么是radioGroupLoanType的选择没有被设置时的值设置。我可以通过使用@DbColumn而不是@DbLookup为radioGroupLoanType创建一个常量值列表来证明这一点。

有关如何做到这一点的任何其他想法?

<xp:br></xp:br> 

<xp:br></xp:br> 
<xp:radioGroup id="radioGroupLoanType" layout="pageDirection"> 



    <xp:eventHandler event="onclick" submit="true" 
     refreshMode="complete"> 
     <xp:this.action><![CDATA[#{javascript:var key = getComponent("radioGroupLoanType").getValue(); 
    if (key == null) return; 

var val = @DbLookup("","vwRateTypesByLoanTypesOrder",key,"RateName"); 
if (@IsError(val) || val.constructor == Array) 
{ 
getComponent("radioGroupRateReq").setValue(""); 

} 
else 
{ 
getComponent("radioGroupRateReq").setValue(val); 


} 
}]]></xp:this.action> 
    </xp:eventHandler> 



    <xp:selectItems> 
     <xp:this.value><![CDATA[#{javascript:@DbColumn("","vwLoanTypesByOrder",2)}]]></xp:this.value> 
    </xp:selectItems> 
</xp:radioGroup><xp:br></xp:br> 
<xp:br></xp:br><xp:radioGroup id="radioGroupRateReq" layout="pageDirection" styleClass="PNCText"> 
       <xp:selectItems> 
        <xp:this.value><![CDATA[#{javascript:var key = getComponent("radioGroupLoanType").getValue(); 
var val = @DbLookup("","vwRateTypesByLoanTypesOrder",key,"RateName"); 
return (@IsError(val) || val == "") ? @DbColumn("","vwRateTypesByOrder",2) : val; 
}]]></xp:this.value> 
       </xp:selectItems> 

      </xp:radioGroup> 
+0

我看到似乎正在发生的事情。在onClick事件中,radioGroupLoanType值尚未更改。但是,只有当我在第二个单选按钮组上设置值时。我被告知onSelect在IE中不起作用,而这正是我需要的。 – 2012-08-01 18:37:06

回答

0

我得到这个范围变量的工作。 radioGroupLoanType的onCLick事件设置radioGroupRateReq的选项并设置值。 radioGroupRateReq使用范围变量中的选择。

有关如何做到这一点的更好的想法?