Asp.Net教程,WinForm教程,Asp.Net MVC,vs2008教程,vs2010教程,Silverlight技术,源码下载,Asp.Net视频教程
全站热门标签
vs2010 Silverlight 存储过程 水晶报表 ADO.NET JavaScript LINQ AjaxPro DataGridView 面向对象 Extjs GridView XML DevExpress HTML教程 Oracle jQuery 分页 GDI+ Visual C++2010 MySQL Office2010 WPF MVC Dojo WCF4.0 VB.NET Sql2005 textbox cookie WCF WinForm Discuz!NT SQL经典语句 T-SQL checkbox ASPxGridView F# asp.net SQL VS2008新特性 DropDownList Access TreeView Ajax VS2008 页面执行时间 Flex 字符串 回调 VB2005 DataSet C#时间 ASP.NET性能优化 用户在线检测 动画
jQuery JavaScript Html/CssFlex Dojo ExtJS AJAX
当前位置: 主页 > Web编程 > Flex >

flex TabNavigator 切换之前给出提示

时间:2010-08-31 00:47来源:未知 作者:admin 点击:

<?xml version="1.0" encoding="utf-8"?>
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml" layout="absolute"
  creationComplete="init()">
<mx:Script>
 <![CDATA[
  import mx.controls.TabBar;
  import mx.controls.Button;
  import mx.controls.Alert;
  import mx.events.CloseEvent;
  import mx.managers.PopUpManager;
 
  private var iTabIndex:int;
  private var iToTabIndex:int;
  private var _updateAlert:Alert;
 
  public function init():void
  {
   iTabIndex = 0;
   iToTabIndex = 0;
   var btn:Button;
   for(var i:int=0;i<tab.getChildren().length;i++)
   {
    btn = tab.getTabAt(i);
    btn.addEventListener(MouseEvent.MOUSE_DOWN,tabClickHandler,false,999999999);
   }
  }
  private function tabClickHandler(event:MouseEvent):void
     {
         iToTabIndex = event.currentTarget.parent.getChildIndex(event.currentTarget);
         //终止事件
         event.stopImmediatePropagation();
         //给出提示message
         if(iToTabIndex !=iTabIndex)
         {
          showGoBack();
         }
     }
     // alert
  public function showGoBack():void
  {
   Alert.buttonWidth = 100;
   Alert.yesLabel    = "yes";
   Alert.noLabel     = "no";
   var updateLabel:String =  "要切换tab吗?";

   this._updateAlert = Alert.show(updateLabel, "", Alert.YES | Alert.NO);
   this._updateAlert.addEventListener(CloseEvent.CLOSE,closeShowGoBack);
  }
  private function closeShowGoBack(e:CloseEvent):void
  {
   switch (e.detail)
   {
    case Alert.YES:            
     iTabIndex    = iToTabIndex;
     tab.selectedIndex   = iTabIndex;
     break;
    case Alert.NO:
     PopUpManager.removePopUp(this._updateAlert);
     break;
   }  
  }
 
  public function change(e:Event):void
  {
   Alert.show("CHANGE " + tab.selectedIndex.toString() + "!!!");
  
  }
  //注释;creationPolicy="all",把tab的所有child全部初始化
 
 
 ]]>
</mx:Script>
 <mx:TabNavigator creationPolicy="all" id="tab" x="21" y="28" change="change(event)" width="200" height="200" >
  <mx:Canvas id="a" label="aa" width="100%" height="100%">
   <mx:TextInput x="10" y="10" width="178"/>
  </mx:Canvas>
  <mx:Canvas id="b" label="bb" width="100%" height="100%">
   <mx:Button id="abtn" x="10" y="50" label="Button"/>
  </mx:Canvas>
 </mx:TabNavigator>
</mx:Application>

(责任编辑:admin)
Tags:Flex
责任编辑:admin
返回顶部
------分隔线----------------------------
推荐内容
骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价 骆驼户外男 真皮磨砂日常休闲鞋 低帮 2011秋冬新款 专柜正品特价