zoukankan      html  css  js  c++  java
  • DataGrid 之右键菜单

         Flex的右键菜单是通过contextMenu来实现的。谈到向DataGrid添加右键菜单,肯定有人会想到直接设置DataGrid的实例(id为dg,后面均用dg代替)的contextMenu属性就行了,还有人会想到通过设置itemRenderer来实现右键菜单功能。

         下面以个人观点分析下着两种方法。具体怎么实现就不说了,主要是谈论下各自的优缺点

         一、设置dg的contextMenu属性,这种方法的优点是代码简单、实现方便、让人容易看懂明白。缺点是,这样添加的右键菜单,是添加到整个dg上面了,在header上以及没有数据的地方都会出现右键菜单。当你想对某条数据实现右键功能时。这种方法很不准确,不能体现当前弹出的菜单对应的是哪条数据,试想header上弹出右键菜单“详细信息”会让人感觉很奇怪。

        二、通过设置itemRenderer来实现右键功能。优点是,它的优点正好弥补了第一种方法的缺点。他能非常准确的显示当前弹出的右键菜单对应的是哪条数据。并且在header和没有数据的地方不会弹出右键菜单,它的缺点是,个人感觉有点复杂,首先得新建itemRenderer类,在这个类里设置右键菜单,然后设置dg的itemRenderer。感觉不太方便比较麻烦。

        于是我想到了我自己的写法:

        其实就是添加了两个函数,感觉挺方便的。

    代码
    //添加右键菜单
    public function addContextMenu(cmArr:Array,menuItemSelFunc:Function):void{
        
    var cm:ContextMenu=new ContextMenu;
        cm.hideBuiltInItems();
        cm.addEventListener(ContextMenuEvent.MENU_SELECT,menuSelectEvt);
        dg.contextMenu
    =cm;
        
    for(var i:uint=0;i<cmArr.length;i++){
            
    var cmi:ContextMenuItem=new ContextMenuItem(cmArr[i],cmArr[i]=="");
            cmi.addEventListener(ContextMenuEvent.MENU_ITEM_SELECT,menuItemSelFunc);
            cm.customItems.push(cmi);
        }
    }
    private 
    function menuSelectEvt(e:ContextMenuEvent):void{
        
    var cm:ContextMenu=e.currentTarget as ContextMenu;
        
    var _dg:DataGrid=e.contextMenuOwner as DataGrid;
        
    var _mouseRow:Number=Math.ceil((_dg.mouseY-_dg.headerHeight)/_dg.rowHeight)-1;
        var dgDataCount:Number=_dg.dataProvider==null?0:(_dg.dataProvider as IList).length;
        
        
    if(_mouseRow<0||_mouseRow>dgDataCount-1){
            
    var enabled:Boolean=false;
            _dg.selectedIndex
    =-1;
        }
    else{
            enabled
    =true;
            _dg.selectedIndex
    =_mouseRow+_dg.verticalScrollPosition;
        }
        
    for(var i:uint=0;i<cm.customItems.length;i++){
            
    var cmi:ContextMenuItem=cm.customItems[i];
            cmi.enabled
    =enabled;
        }
        _dg.validateNow();
    }

          用的时候调用addContextMenu就行了。这个函数有两个参数,第一个是菜单数据,如:['详细信息','相关文件'],第二个参数就是菜单事件了。

          它的特点是,当鼠标点击到header或没有数据的地方时菜单是灰色的,只有点击到数据上时菜单才可用

  • 相关阅读:
    项目Alpha冲刺Day7
    项目Alpha冲刺Day5
    项目Alpha冲刺Day6
    Alpha冲刺总结
    测试随笔
    项目Alpha冲刺Day12
    高校征信系统项目Postmortem结果
    冲刺合集
    总结随笔
    测试工作安排
  • 原文地址:https://www.cnblogs.com/huomiao/p/1891260.html
Copyright © 2011-2022 走看看