`

FLEX在某控件上创建右键实例

    博客分类:
  • flex
阅读更多

通过ContextMenu和ContextMenuItem类在DataGrid控件上添加右键.

示例:
<?xml version="1.0" encoding="utf-8"?>
<!-- http://blog.flexexamples.com/2007/08/20/using-a-custom-context-menu-with-the-flex-datagrid-control/ -->
<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("View item", true);
                cmi.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT, contextMenuItem_menuItemSelect);

                cm = new ContextMenu();
                cm.hideBuiltInItems();
                cm.customItems = [cmi];
                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);
            }
        ]]>
    </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右键菜单 flex tree 右键菜单 源码

    在Flex中,右键菜单是用户交互的重要组成部分,特别是在数据可视化和树形结构的数据展示中,如Flex Tree组件。本文将深入探讨如何在Flex中实现右键菜单,并结合提供的源码进行分析。 1. Flex右键菜单: Flex中的...

    flex右键菜单代码

    2. **创建ContextMenu对象**:在Flex中,你可以通过实例化`ContextMenu`类来创建一个右键菜单。 ```actionscript var contextMenu:ContextMenu = new ContextMenu(); ``` 3. **添加菜单项**:使用`ContextMenu`...

    flex组件介绍

    Flex控件的使用通常遵循以下步骤:创建控件实例、设置属性、添加事件监听器、将控件添加到容器中。例如,要创建一个按钮并添加到界面上,首先需要实例化按钮组件,然后通过设置其属性来定义按钮的样式和行为,接着...

    用Flash Builder和openscales创建地图实例

    在Flash Builder中,可以通过右键点击项目 -&gt; “属性” -&gt; “Flex Build Path” -&gt; “库路径”来进行添加。 3. **创建地图组件**:在主视图的MXML文件中,创建一个`mx:Canvas`元素作为地图容器。然后,引入...

    构建Flex4为前端的Java EE项目

    这一整合不仅能够利用Flex4丰富的用户界面组件库来提高用户体验,还能充分发挥Java EE在后端处理上的强大功能,实现前后端的高效协同工作。整个过程分为四个主要步骤:添加Apache Tomcat运行时、使用WTP创建Java/...

    as3/flex4.6

    2. **创建新项目**:通过菜单栏的“文件”-&gt;“新建”-&gt;“Flex项目”或在包资源管理器中右键选择“新建”-&gt;“Flex项目”来创建项目。 3. **配置项目信息**:输入项目名称等相关信息,完成项目创建。 #### 五、总结 ...

    Flex ContextMenu

    在Flex中,`ContextMenu`类是用于创建和管理应用程序中的右键菜单的关键组件。这个`Flex ContextMenu`专题主要关注如何自定义Flex应用的右键菜单,以及在处理输入法和不透明度问题时可能遇到的技术细节。 首先,让...

    flex3的cookbook书籍完整版dpf(包含目录)

    在TextInput及TextArea控件上使用Validator 和Formatter 15.2节. 如何创建一个自定义的Formatter 15.3节. 使用正则表达式创建国际化邮政编码Validator 15.4节. 如何创建一个Validator去验证通用商品代码(UPC) 15.5...

    Flash CS3 中fl.*类库在 FB 中如何使用

    标题中的“Flash CS3 中fl.*类库在 FB 中如何使用”指的是在使用Adobe Flash CS3开发工具时,如何在FlexBuilder(现称为Flash Builder)中利用fl.*类库进行项目开发。fl.*类库是Flash Professional CS3中提供的一...

Global site tag (gtag.js) - Google Analytics