Come scorrere le schede nella barra delle schede flessibile
-
05-07-2019 - |
Domanda
Sono un principiante flessibile. Devo disabilitare alcune delle schede in una tabbar flessibile specificata, in base alla configurazione. Ho problemi a scorrere le schede nella barra delle schede. Se uso il comando getChildAt (), non disabilita il pulsante tab, ma il contenuto di quel pulsante tab, quindi non va bene.
Grazie e saluti, Mohit Ranka
Soluzione
Quando chiedi del codice, pubblica sempre un test case minimo. getChildAt ()
funzionerà, quindi c'è qualcos'altro che succede nel tuo codice.
<mx:Script>
<![CDATA[
import mx.events.ItemClickEvent;
import mx.controls.tabBarClasses.Tab;
private function clickTab(event:ItemClickEvent):void {
var target:TabBar = event.currentTarget as TabBar;
var currTab:Tab;
var parity:int = event.index & 1;
/* disable all tabs at indices w/ same parity as clicked tab;
enable tabs of opposite parity.
*/
for (var i=0; i<target.numChildren; ++i) {
currTab = target.getChildAt(i) as Tab;
currTab.enabled = (i&1)^parity;
}
}
]]>
</mx:Script>
<mx:TabBar id="someTabs" itemClick="clickTab(event)">
<mx:dataProvider>
<mx:String>Foo</mx:String>
<mx:String>Bar</mx:String>
<mx:String>Baz</mx:String>
<mx:String>Bam</mx:String>
</mx:dataProvider>
</mx:TabBar>
Altri suggerimenti
perché non utilizzare un binding alla tua configurazione?
qualcosa come
enabled="{yourConfiguration.lastResult.enabled}"
Per chi desidera una risposta funzionante per Flex 4.5 (probabilmente anche Flex 4). Alla fine ho trovato una soluzione. Mi sembra un trucco, ma Adobe non risponde alla chiamata e funziona per me. Ecco un esempio semplificato.
<!-- component that has the the TabBar in it... -->
<fx:Script>
<![CDATA[
//imports here
import mx.core.UIComponent;
//imports
private function setTabEnabled(index:int,enabled:Boolean):void{
var theTab:UIComponent = theTabBar.dataGroup.getElementAt(index) as UIComponent;
if(theTab){theTab.enabled = enabled;}
}
]]>
</fx:Script>
<s:TabBar id="theTabBar"
dataProvider="{viewStack}"/>
<mx:ViewStack id="viewStack">
<s:NavigatorContent label="0th Tab">
<!-- ...Content -->
</s:NavigatorContent>
<s:NavigatorContent label="1st Tab">
<!-- ...Content -->
</s:NavigatorContent>
<s:NavigatorContent label="2nd Tab">
<!-- ...Content -->
</s:NavigatorContent>
</mx:ViewStack>
<!-- rest of the component that has the the TabBar in it... -->
Quindi basta chiamare setTabEnabled (theTabIndex, trueFalse)
in un gestore eventi relativo a qualunque cosa decida perché la scheda è o non è abilitata.
I dovrei estendere TabBar per supportarlo, ma ho già trascorso abbastanza tempo a cercare di capirlo.
Happy Coding = D