Dictionary<实体,List<实体>>的比较

解决Dictionary中实体Key比较问题
本文探讨了在使用Dictionary时,实体作为Key时比较存在的问题,并提供了通过实体类重写Equals方法解决的方法。

当Dictionary中Key为实体时,进行用ContainsKey比较会发现,就算Model为一样但是结果比较为不存在;

故用以下代码即可,现将Keys转换ToArray(),再用数组的Contains进行比较;

但是一定要注意:要进行对实体类重写Equals,比较实体内某个字段相等,则存在;

var MenuModel = new Dictionary<MenuGroupModel, List<MenuButtonModel>>();
//忽略MenuModel增加数据
var navBarData = new Dictionary<MenuGroupModel, List<MenuButtonModel>>();
//忽略navBarData增加数据
foreach (var menuInfo in MenuModel)
{
     //调用MenuGroupModel重写的Equals,MenuGroupSort相同即Model相同
     if (navBarData.Keys.ToArray().Contains(menuInfo.Key))
     {
         //是否存在
     }
 }
namespace Model
{
    public class MenuGroupModel
    {
        public string MenuGroupSort { get; set; }
        public string MenuGroupName { get; set; }

        /// <summary>
        /// 重写两个Model进行比较时:MenuGroupSort相等即Model相同
        /// </summary>
        /// <param name="obj"></param>
        /// <returns></returns>
        public override bool Equals(object obj)
        {
            return MenuGroupSort == (((MenuGroupModel)obj).MenuGroupSort);
        }
    }

    public class MenuButtonModel
    {
        public string Sort { get; set; }
        public string Name { get; set; }
        public string TargetModule { get; set; }
        public string Image { get; set; }
        /// <summary>
        /// 重写两个Model进行比较时:MenuGroupSort相等即Model相同
        /// </summary>
        /// <param name="obj"></param>
        /// <returns></returns>
        public override bool Equals(object obj)
        {
            return Sort == (((MenuButtonModel)obj).Sort);
        }

    }
}

 

转载于:https://www.cnblogs.com/kingsly/p/3968259.html

<Window x:Class="FengJing.Views.OtherView.PlantList" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:FengJing.Views.OtherView" mc:Ignorable="d" Title="苗木信息管理" Height="600" Width="1200" WindowStartupLocation="CenterScreen"> <Window.Resources> <!-- 按钮样式 --> <Style TargetType="Button" x:Key="ActionButton"> <Setter Property="Margin" Value="2"/> <Setter Property="Padding" Value="5,2"/> <Setter Property="MinWidth" Value="60"/> </Style> <!-- 搜索框样式 --> <Style TargetType="TextBox" x:Key="SearchBox"> <Setter Property="Margin" Value="5"/> <Setter Property="Padding" Value="5"/> <Setter Property="MinWidth" Value="200"/> </Style> <!-- 数据网格样式 --> <Style TargetType="DataGrid"> <Setter Property="Margin" Value="10"/> <Setter Property="AutoGenerateColumns" Value="False"/> <Setter Property="CanUserAddRows" Value="False"/> <Setter Property="CanUserDeleteRows" Value="False"/> <Setter Property="SelectionMode" Value="Single"/> <Setter Property="IsReadOnly" Value="True"/> <Setter Property="RowHeaderWidth" Value="0"/> <Setter Property="VerticalScrollBarVisibility" Value="Auto"/> <Setter Property="HorizontalScrollBarVisibility" Value="Auto"/> </Style> <!-- 数字列样式 --> <Style TargetType="DataGridTextColumn"> <Setter Property="ElementStyle"> <Setter.Value> <Style TargetType="TextBlock"> <Setter Property="HorizontalAlignment" Value="Right"/> <Setter Property="Margin" Value="0,0,10,0"/> </Style> </Setter.Value> </Setter> </Style> </Window.Resources> <Grid> <Grid.RowDefinitions> <RowDefinition Height="Auto"/> <RowDefinition Height="*"/> <RowDefinition Height="Auto"/> <RowDefinition Height="Auto"/> <!-- 新增:水平滚动条 --> <RowDefinition Height="Auto"/> <!-- 状态栏 --> </Grid.RowDefinitions> <!-- 工具栏 --> <StackPanel Orientation="Horizontal" Margin="10" Grid.Row="0"> <Button Content="添加苗木" Command="{Binding AddPlantCommand}" Style="{StaticResource ActionButton}" Background="#4CAF50" Foreground="White" Click="Button_Click_Create" Height="33.24"/> <Button Content="刷新列表" Command="{Binding RefreshCommand}" Style="{StaticResource ActionButton}" Height="33.24"/> <TextBox Text="{Binding SearchText, UpdateSourceTrigger=PropertyChanged}" Style="{StaticResource SearchBox}" Tag="输入苗木名称搜索..." Height="33.24"/> <Button Content="搜索苗木" Command="{Binding SearchCommand}" Style="{StaticResource ActionButton}" Margin="5,0,0,0" Height="33.24"/> <Button Content="导入苗木列表" Command="{Binding ImportCommand}" Style="{StaticResource ActionButton}" Margin="5,0,0,0" Height="33.24" Background="#2196F3" Foreground="White"/> </StackPanel> <!-- 数据网格 --> <DataGrid x:Name="PlantDataGrid" ItemsSource="{Binding Plants}" Grid.Row="1" SelectedItem="{Binding SelectedPlant}"> <DataGrid.Columns> <DataGridTextColumn Header="序号" Binding="{Binding Id}" Width="60"/> <DataGridTextColumn Header="苗木名称" Binding="{Binding Name}" Width="100"/> <DataGridTextColumn Header="类型" Binding="{Binding Type}" Width="60"/> <DataGridTextColumn Header="颜色" Binding="{Binding Color}" Width="60"/> <DataGridTextColumn Header="单位" Binding="{Binding Unit}" Width="60"/> <DataGridTextColumn Header="适生地区" Binding="{Binding SuitableRegion}" Width="120"/> <DataGridTextColumn Header="生长习性" Binding="{Binding Habit}" Width="120"/> <DataGridTextColumn Header="奈湿奈旱性" Binding="{Binding WetDroughtTolerance}" Width="70"/> <DataGridTextColumn Header="是否海绵类" Binding="{Binding IsSpongePlant}" Width="70"/> <DataGridTextColumn Header="常绿落叶性" Binding="{Binding EvergreenDeciduous}" Width="80"/> <DataGridTextColumn Header="观赏价值" Binding="{Binding OrnamentalValue}" Width="80"/> <DataGridTextColumn Header="色叶期" Binding="{Binding ColorPeriod}" Width="70"/> <DataGridTextColumn Header="胸径/地径(cm)" Binding="{Binding Diameter, StringFormat={}{0:F2}}" Width="100"/> <DataGridTextColumn Header="高度(cm)" Binding="{Binding Height, StringFormat={}{0:F2}}" Width="80"/> <DataGridTextColumn Header="冠幅(cm)" Binding="{Binding CrownWidth, StringFormat={}{0:F2}}" Width="80"/> <DataGridTextColumn Header="信息价(元)" Binding="{Binding Price, StringFormat={}{0:N2}}" Width="100"/> <DataGridTextColumn Header="创建时间" Binding="{Binding CreateAt, StringFormat=yyyy-MM-dd HH:mm:ss}" Width="130"/> <DataGridTextColumn Header="更新时间" Binding="{Binding LastUpdatedAt, StringFormat=yyyy-MM-dd HH:mm:ss}" Width="130"/> <!-- 操作列 --> <DataGridTemplateColumn Header="操作" Width="190"> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <StackPanel Orientation="Horizontal"> <!-- 新增的查看图片按钮 --> <Button Content="查看图片" Command="{Binding DataContext.ViewImageCommand, RelativeSource={RelativeSource AncestorType=DataGrid}}" CommandParameter="{Binding}" Style="{StaticResource ActionButton}" Background="#4CAF50" Foreground="White" Margin="0,0,5,0"/> <Button Content="编辑" Command="{Binding DataContext.EditPlantCommand, RelativeSource={RelativeSource AncestorType=DataGrid}}" CommandParameter="{Binding}" Style="{StaticResource ActionButton}" Background="#2196F3" Foreground="White"/> <Button Content="删除" Command="{Binding DataContext.DeletePlantCommand, RelativeSource={RelativeSource AncestorType=DataGrid}}" CommandParameter="{Binding}" Style="{StaticResource ActionButton}" Background="#F44336" Foreground="White"/> </StackPanel> </DataTemplate> </DataGridTemplateColumn.CellTemplate> </DataGridTemplateColumn> </DataGrid.Columns> </DataGrid> <!-- 分页控制 --> <StackPanel Orientation="Horizontal" HorizontalAlignment="Center" Grid.Row="2" Margin="0,10"> <Button Content="首页" Command="{Binding FirstPageCommand}" Style="{StaticResource ActionButton}"/> <Button Content="上一页" Command="{Binding PreviousPageCommand}" Style="{StaticResource ActionButton}"/> <TextBlock Text="{Binding CurrentPage, StringFormat='第 {0} 页'}" VerticalAlignment="Center" Margin="10,0"/> <Button Content="下一页" Command="{Binding NextPageCommand}" Style="{StaticResource ActionButton}"/> <Button Content="末页" Command="{Binding LastPageCommand}" Style="{StaticResource ActionButton}"/> <TextBlock Text="每页数量:" VerticalAlignment="Center" Margin="10,0,5,0"/> <ComboBox ItemsSource="{Binding PageSizeOptions}" SelectedItem="{Binding PageSize}" Width="80" Margin="0,0,10,0"/> <TextBlock Text="{Binding TotalCount, StringFormat='共 {0} 条记录'}" VerticalAlignment="Center"/> </StackPanel> <!-- 新增:独立水平滚动条 (Grid.Row="3") --> <!--<ScrollBar Grid.Row="3" Orientation="Horizontal" Minimum="0" Maximum="{Binding ScrollableWidth, ElementName=MainDataGrid}" ViewportSize="{Binding ViewportWidth, ElementName=MainDataGrid}" Value="{Binding HorizontalOffset, ElementName=MainDataGrid, Mode=TwoWay}" Height="20" Margin="10,5,10,5" Visibility="{Binding HasHorizontalScroll, ElementName=MainDataGrid, Converter={StaticResource BoolToVisibilityConverter}}"/>--> <!-- 状态栏 --> <StatusBar Grid.Row="2" VerticalAlignment="Bottom"> <StatusBarItem> <TextBlock Text="{Binding StatusMessage}"/> </StatusBarItem> </StatusBar> </Grid> </Window> 搜索苗木改为精确搜索,可根据“苗木名称”、“类型”、“颜色”、“单位”、”适生地区”、“生长习性”、“耐湿耐寒性”、“是否海绵类”、”常绿落叶性”、“观赏价值”、“色叶期”、“胸径/地径(cm)”、“高度(cm)”、“冠幅(cm)”、“信息价(元)”进行精确搜索,且搜索条件可以为一个也可以为多个。根据以上条件写出代码
07-19
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值