Puis-je lier une propriété de composant Flex à une fonction?
-
22-07-2019 - |
Question
Je souhaite définir la propriété activée sur un bouton en fonction de la valeur de retour d'une fonction comportant un ou plusieurs paramètres. Comment puis-je faire cela?
private function isUserAllowed (userName:Boolean):Boolean {
if (userName == 'Tom')
return true;
if (userName == 'Bill')
return false;
}
<mx:Button label="Create PO" id="createPOButton"
enabled="<I want to call isUserAllowed ('Bill') or isUserAllowed ('Tom') here>"
click="createPOButton_Click()" />
La solution
<mx:Button
enabled = "{this.myFunction(this.myVariable)}"
>
ou en ligne:
<mx:Button
enabled = "{(function(arg:Object):Boolean{ ... })(this.myVariable)}"
>
Autres conseils
Selon les documents Flex , tant que la propriété est reliable, vous pouvez simplement le faire (j'ai inclus les deux boutons supplémentaires à démontrer):
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute">
<mx:Script>
<![CDATA[
[Bindable]
private var currentUser:String = "Bill";
private function isUserAllowed(user:String):Boolean
{
if (user == "Bill")
{
return true;
}
return false;
}
]]>
</mx:Script>
<mx:VBox>
<mx:Button label="My Button" enabled="{isUserAllowed(currentUser)}" />
<mx:HBox>
<mx:Button label="Try Tom" click="{currentUser = 'Tom'}" />
<mx:Button label="Try Bill" click="{currentUser = 'Bill'}" />
</mx:HBox>
</mx:VBox>
</mx:Application>
Sans currentUser marqué [Bindable], cela ne fonctionnera pas.
Une autre façon de procéder, si vous souhaitez vous lier plus littéralement à la fonction (cela est également exprimé dans la documentation), consiste à faire en sorte que la fonction réponde à un événement que vous envoyez lorsque l'utilisateur actuel change, comme suit:
<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute" initialize="init()">
<mx:Script>
<![CDATA[
private var _currentUser:String = "Bill";
public function set currentUser(value:String):void
{
if (_currentUser != value)
{
_currentUser = value;
dispatchEvent(new Event("userChanged"));
}
}
[Bindable(event="userChanged")]
private function isUserEnabled():Boolean
{
if (_currentUser == "Bill")
{
return true;
}
return false;
}
]]>
</mx:Script>
<mx:VBox>
<mx:Button label="My Button" enabled="{isUserEnabled()}" />
<mx:HBox>
<mx:Button label="Try Tom" click="{currentUser = 'Tom'}" />
<mx:Button label="Try Bill" click="{currentUser = 'Bill'}" />
</mx:HBox>
</mx:VBox>
</mx:Application>
Donc, il y a deux façons. OMI, la seconde semble en quelque sorte plus appropriée, mais il n'y a définitivement aucun problème avec la première. Bonne chance!
Voici ce que j'ai déjà fait à quelques reprises dans des circonstances similaires:
<mx:Script>
<![CDATA[
[Bindable] var _username : String;
private function isUserAllowed (userName:Boolean):Boolean {
if (userName == 'Tom')
return true;
if (userName == 'Bill')
return false;
}
]]>
</mx:Script>
<mx:Button label="Create PO"
id="createPOButton"
enabled="{isUserAllowed(_username)}"
click="createPOButton_Click()" />
Ainsi, lorsque Bindable _username
change, une notification de modification est déclenchée. Etant donné que l'étiquette écoute les modifications _nom_utilisateur
(même s'il s'agit simplement d'un paramètre d'une autre fonction), la propriété activé
sera réévaluée.
<mx:Script>
<![CDATA[
[Bindable]
private var userName : String = "Tom"; // or whatever ...
[Bindable]
private var userAllowed : Boolean;
private function isUserAllowed ():Boolean {
if (userName == 'Tom')
return false;
if (userName == 'Bill')
return false;
return false;
}
]]>
</mx:Script>
<mx:Button label="Create PO" id="createPOButton" enabled="{userAllowed}" addedToStage="isUserAllowed()"/>