2009-11-21 56 views
2

我在我的应用程序中有一个组合框。我也有一个名为“状态”的变量。我希望仅当Status变量的值为5或6时启用组合框。否则,我不应该能够更改组合框中的值。它应该只有以前的值..如何在某些情况下禁用组合框的下拉功能?

我写了一个单击事件来禁用组合框。但即使组合框被禁用,我也会看到组合框的下拉列表,如果我在下拉列表中选择了其他值,它就会改变..只有在它被禁用后。

如何避免这一点?我希望禁用下拉功能本身。 这是我写的代码。有人指导我。

<mx:FormItem label="Review Status:" width="100%" horizontalAlign="right"> 
    <mx:HBox> 
    <mx:Label width="30"/> 
     <mx:ComboBox id="reviewStatus" dataProvider="{Status}" 
        width="150" click="onStatusChange(event)"/> 
    </mx:HBox> 

动作脚本部分:

private function onStatusChange(event:Event):void 
{ 
    var i:int; 
    for(i=0;i<defectDetails.length;i++) 
    { 
    var defStatusId:String=defectDetails.getItemAt(i).DefectStatusId; 
    if(defStatusId=="5"){ 
       reviewStatus.enabled=true; 
    } 
    else if(defStatusId=="6"){ 
       reviewStatus.enabled=true; 
    } 
    else{ 
       reviewStatus.enabled=false; 
      //reviewStatus.selectedItem.label="Review"; 
      reviewStatus.toolTip="Status can be changed only if Defect Status is Verified or Deferred."; 

       //Alert.show("Status can be changed only if defect status is verified or deferred"); 
    } 
    } 
    } 

如果我使用Change事件也首次值被改变。只有在此之后,组合框才被禁用。当状态不是5或6时,如何保留相同的值并禁用组合框?

回答

0

在启用设置为false之前调用reviewStatus.close()

你为什么要在ComboBox的click事件上做?更好地在defectDetails(或使用defectDetails作为其dataProvider的控件)的更改事件上执行此操作。

顺便说一句,那里有另一个潜在的错误:你设置enabled值在一个循环,并没有打破设置后的循环。 reviewStatus.enabled的最终值将完全取决于最后一项 - defectDetails.getItemAt(defectDetails.length - 1)

另外,当enabled为真时,您没有将工具提示设置恢复正​​常。

0

为什么是循环?你能不能抓上的状态更改selectedItem属性为INT,即:

reviewStatus.enabled = ((reviewStatus.selectedItem as Int)) == 5 || (reviewStatus.selectedItem as Int) == 6) ? false : true; 

一度已被停用,你可能不会被recieving更多StatusChange事件,对吧?

0

也许,您可以在'enabled'上为'reviewStatus'使用绑定功能。像,

<mx:ComboBox id="reviewStatus" enabled = {checkEnabledForReviewStatus(defectStatusId)} /> 

而在脚本部分,

private function checkEnabledForReviewStatus(defectStatusId:String):Boolean 
{ 
    return (defectStatusId == "5" || defectStatusId == "6") ? true: false; 
}