flex4 自定义右键菜单

<?xml version="1.0" encoding="utf-8"?>  
<mx:Application xmlns:mx="http://www.adobe.com/2006/mxml"  
        layout="vertical"  
        verticalAlign="middle"  
        backgroundColor="white"  
        creationComplete="init()">  
   
    <mx:Script>  
        <![CDATA[ 
            import mx.controls.Alert; 
  
            [Bindable] 
            private var cm:ContextMenu; 
  
            private var alert:Alert; 
  
            private function init():void { 
                var cmi:ContextMenuItem = new ContextMenuItem("菜单项", true); 
                cmi.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT, contextMenuItem_menuItemSelect); 
                var cmi1:ContextMenuItem = new ContextMenuItem("菜单项1", false); 
                cmi1.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT, contextMenuItem_menuItemSelect1); 
                 
                cm = new ContextMenu(); 
                cm.hideBuiltInItems(); 
                cm.customItems = [cmi,cmi1]; 
                cm.addEventListener(ContextMenuEvent.MENU_SELECT, contextMenu_menuSelect); 
            } 
  
            private function contextMenu_menuSelect(evt:ContextMenuEvent):void { 
                dataGrid.selectedIndex = lastRollOverIndex; 
            } 
  
            private function contextMenuItem_menuItemSelect(evt:ContextMenuEvent):void { 
                var obj:Object = dataGrid.selectedItem; 
                alert = Alert.show("Property A: " + obj.@propertyA + "\n" + "Property B: " + obj.@propertyB, obj.@label, Alert.OK); 
            } 
            private function contextMenuItem_menuItemSelect1(evt:ContextMenuEvent):void { 
                var obj:Object = dataGrid.selectedItem; 
                alert = Alert.show("Property A: " + obj.@propertyA + "\n" + "Property B: " + obj.@propertyB, obj.@label, Alert.OK); 
            } 
        ]]>  
    </mx:Script>  
   
    <mx:XML id="itemsXML">  
        <items>  
            <item label="Item 1" data="i001" propertyA="Item 1.A" propertyB="Item 1.B" />  
            <item label="Item 2" data="i002" propertyA="Item 2.A" propertyB="Item 2.B" />  
            <item label="Item 3" data="i003" propertyA="Item 3.A" propertyB="Item 3.B" />  
            <item label="Item 4" data="i004" propertyA="Item 4.A" propertyB="Item 4.B" />  
            <item label="Item 5" data="i005" propertyA="Item 5.A" propertyB="Item 5.B" />  
            <item label="Item 6" data="i006" propertyA="Item 6.A" propertyB="Item 6.B" />  
            <item label="Item 7" data="i007" propertyA="Item 7.A" propertyB="Item 7.B" />  
            <item label="Item 8" data="i008" propertyA="Item 8.A" propertyB="Item 8.B" />  
        </items>  
    </mx:XML>  
   
    <mx:Number id="lastRollOverIndex" />  
   
    <mx:DataGrid id="dataGrid"  
            width="400"  
            dataProvider="{itemsXML.item}"  
             contextMenu="{cm}"  
             itemRollOver="lastRollOverIndex = event.rowIndex">  
        <mx:columns>  
            <mx:DataGridColumn id="labelCol"  
                    dataField="@label"  
                    headerText="Label:" />  
   
            <mx:DataGridColumn id="propACol"  
                    dataField="@propertyA"  
                    headerText="Property A:" />  
   
            <mx:DataGridColumn id="propBCol"  
                    dataField="@propertyB"  
                    headerText="Property B:" />  
        </mx:columns>  
    </mx:DataGrid>  
   
    <mx:Label text="{dataGrid.selectedItem.@label}" />  
   
</mx:Application>  

下面这个例子给Flex的右键添加一个自定义的菜单,并且在点击菜单内容时,执行事件

var copyrightMenuItem:ContextMenuItem = new ContextMenuItem("菜单内容",true,true);<br>

copyrightMenuItem.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT,function(e:ContextMenuEvent){
    Alert.show((e.currentTarget
as ContextMenuItem).caption);
});
var contextMenuCustomItems:Array =
 FlexGlobals.topLevelApplication.contextMenu.customItems;
contextMenuCustomItems.push(copyrightMenuItem);

我使用的是Flex4,如果是Flex3,需要把var contextMenuCustomItems:Array = FlexGlobals.topLevelApplication.contextMenu.customItems;

替换为var contextMenuCustomItems:Array = application.contextMenu.customItems;


1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值