DataGrid 之右键菜单

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

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

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

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

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

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

ExpandedBlockStart.gif 代码
// 添加右键菜单
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或没有数据的地方时菜单是灰色的,只有点击到数据上时菜单才可用

转载于:https://www.cnblogs.com/huomiao/archive/2010/11/29/1891260.html

在WPF中,可以通过以下步骤为DataGrid增加右键菜单: 1. 首先,在XAML文件中定义一个ContextMenu,用于作为右键菜单的内容。可以在Window或者UserControl的资源部分定义ContextMenu,例如: ```xaml <Window.Resources> <ContextMenu x:Key="DataGridContextMenu"> <MenuItem Header="编辑" Click="EditMenuItem_Click"/> <MenuItem Header="删除" Click="DeleteMenuItem_Click"/> </ContextMenu> </Window.Resources> ``` 2. 然后,在DataGrid的样式中,使用EventSetter来为DataGrid的PreviewMouseRightButtonDown事件添加处理程序。在处理程序中,将ContextMenu设置为右键菜单,并设置菜单的PlacementTarget为DataGrid,以确保菜单DataGrid关联。例如: ```xaml <DataGrid> <DataGrid.RowStyle> <Style TargetType="DataGridRow"> <EventSetter Event="PreviewMouseRightButtonDown" Handler="DataGridRow_PreviewMouseRightButtonDown"/> </Style> </DataGrid.RowStyle> </DataGrid> ``` 3. 最后,在代码文件中实现事件处理程序,将ContextMenu设置为右键菜单,并将菜单的PlacementTarget设置为DataGrid。例如: ```csharp private void DataGridRow_PreviewMouseRightButtonDown(object sender, MouseButtonEventArgs e) { DataGridRow row = sender as DataGridRow; if (row != null) { DataGrid dataGrid = FindVisualParent<DataGrid>(row); if (dataGrid != null) { ContextMenu contextMenu = dataGrid.Resources["DataGridContextMenu"] as ContextMenu; if (contextMenu != null) { contextMenu.PlacementTarget = dataGrid; contextMenu.IsOpen = true; e.Handled = true; } } } } private static T FindVisualParent<T>(UIElement element) where T : UIElement { UIElement parent = element; while (parent != null) { T foundElement = parent as T; if (foundElement != null) { return foundElement; } parent = VisualTreeHelper.GetParent(parent) as UIElement; } return null; } ``` 这样,当在DataGrid的行上右键点击时,就会显示出定义的右键菜单
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值