RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1610491
Accepted
Rustam
Rustam
Asked:2025-04-17 18:46:16 +0000 UTC2025-04-17 18:46:16 +0000 UTC 2025-04-17 18:46:16 +0000 UTC

C# wpf 如何删除DataGrid中的一行?

  • 772

我不懂 C#,我正在从例子中、从我的错误和失败中慢慢学习。))。我观察其他人是如何做的,并将代码片段应用到我的项目中。今天我制作了一个应用程序(使用 MVVM),其窗口分为两部分,左侧部分(侧边栏)有一个菜单,右侧部分有来自不同用户控件的内容。将 SQLite 数据库与 EF 连接并迁移到项目。数据输入到数据库并显示在 DataGrid 中。但卡在删除上,或者更确切地说,卡在删除已删除行的显示上。那些。在数据库中,该行已被删除,但 DataGrid 并未发生改变。我将尽我所能描述现在的情况:有一个带有 DataGrid 的 UserControl,并且显示的每行都有一个按钮。以下是 Reports.xaml 文件的 View 文件夹中的一些代码

<UserControl x:Class= ...>
   <UserControl.DataContext>
        <vm:ReportsVM/>
   </UserControl.DataContext> ...
...
<DataGrid  x:Name="ReportsDataGrid"
          ItemsSource = "{Binding Source={x:Static vm:ReportsVM.reportsView}}" 
          SelectedCellsChanged="NO_SelectedCellsChanged"> ....
 ...
 <Button  Name="BtnReportRemove"  
            Content="Удалить отчет"
            Tag="{Binding id_report}"
            CommandParameter="{Binding Path=Tag, RelativeSource={RelativeSource Self}}"
            Command="{Binding Path=DataContext.DeleteReportCommand, RelativeSource={RelativeSource AncestorType=UserControl}}"/>
... 

我从数据库中获取DataGrid的数据,有这样一个类:

public static List<ReportModel> GetAllReports()
{
    using (var db = new ContextModel())
    {
        return db.dbReportTable.OrderBy(b => b.id_report).ToList();
    }
}

并将它们放入一个集合中,在 ViewModel 中有以下代码:

 private ObservableCollection<ReportModel> reports;
 public ObservableCollection<ReportModel> Reports
 { 
     get { return reports; }
     set { Set(ref reports, value); }
 }
public static CollectionViewSource reportsView = new CollectionViewSource();
...

...
public ReportsVM()
{
    DeleteReportCommand = new LambdaCommand(OnDeleteReportExecuted, CanDeleteReportExecute);

    Reports = new ObservableCollection<ReportModel>(ReportData.GetAllReports());
    reportsView = new CollectionViewSource();
    reportsView.Source = Reports;
}

由于我将 id_report 链接到按钮Tag="{Binding id_report}",因此在 ViewModel 命令中我从数据库中删除了具有给定 id_report 的行。删除 ViewModel 中的命令代码

// Команда удаления строки из БД и DataGrid
public ICommand DeleteReportCommand { get; set; }
private bool CanDeleteReportExecute(object p) => true;
private void OnDeleteReportExecuted(object p)
{    
    int cnv1;
    cnv1 = Convert.ToInt32(p);
    MessageBoxResult result = MessageBox.Show("Вы действительно хотите удалить Отчет?", "Удаление", MessageBoxButton.YesNo, MessageBoxImage.Question);
    if ( result == MessageBoxResult.No) return;
    using (ContextModel db = new ContextModel())
    {
        var orderInDb = db.dbReportTable.First(x => x.id_report == cnv1);
        db.dbReportTable.Remove(orderInDb);
        db.SaveChanges();
    }
    
    var collection = reports;
    var item = collection.Where(X => X.id_report == cnv1).FirstOrDefault();
    int index = collection.IndexOf(item);
    reports.RemoveAt(index);
    //Reports.Clear();
    //Reports = new ObservableCollection<ReportModel>(ReportData.GetAllReports());
    //((ObservableCollection<ReportModel>)reportsView.Source).Clear(); 
}

我尝试执行注释中的行,但没有任何效果。那些。该行从数据库中删除,该行从集合中删除(断点显示集合中没有具有选定索引的行),但 DataGrid 中没有任何变化,如果我仅从这个 UserControl 移动到另一个 UserControl 然后返回,则变化是可见的。我认为这里有一些基本而简单的东西,我已经尝试了第三天来寻找它)模型中的数据模型

public class ReportModel 
{
    [Key]
    public int id_report { get; set; }

    public string? name_report { get; set; }
    public string? date_report { get; set; }
}
c#
  • 2 2 个回答
  • 53 Views

2 个回答

  • Voted
  1. Rustam
    2025-04-17T20:45:59Z2025-04-17T20:45:59Z

    在 ViewModel 中的 @EvgeniyZ 示例中,我更正了一行并删除了一行,注释行就是那里的内容

     private ObservableCollection<ReportModel> reports;
     public ObservableCollection<ReportModel> Reports
     { 
         get { return reports; }
         set { Set(ref reports, value); }
     }
      public static CollectionViewSource reportsView = new();
    //public static CollectionViewSource reportsView = new CollectionViewSource();
    ...
    
    ...
    public ReportsVM()
    {
        DeleteReportCommand = new LambdaCommand(OnDeleteReportExecuted, CanDeleteReportExecute);
    
        Reports = new ObservableCollection<ReportModel>(ReportData.GetAllReports());
        //reportsView = new CollectionViewSource();
        reportsView.Source = Reports;
    }
    

    现在一切正常,按下 DB 中的按钮即可删除行,并在 DataGrid 中删除该行。

    • 2
  2. Best Answer
    EvgeniyZ
    2025-04-17T21:18:34Z2025-04-17T21:18:34Z

    这不是答案,只是对代码的一些评论,我认为了解这些评论会很有用。

    1. DataContext在 XAML 中这很糟糕(为什么)。
    2. 您不应该设置DataContext控件,因为它们默认为父上下文,这在 90% 的情况下就足够了。如果您设置了控件的上下文,那么数据源就会出现问题,因为在正常项目中,在创建主窗口时设置一次上下文就足够了。
    3. x:Name不应该,只有当您想通过 XAML 访问所需的控件(样式/触发器)时才如此,而不是通过 c# 代码!
    4. Tag- 这是一个拐杖……而且非常奇怪,因为首先你绑定Tag,然后寻找这个标签并将其转移到CommandParameter,是什么阻止你立即这样做?好吧,关键在于标签意味着设计中出现了问题,你被迫将重要数据存储在 UI 代码中。
    5. 通过绑定x:Static是解决不清楚的问题的另一个手段。您的代码中不能有任何静态对象,并且所有绑定都必须是公共属性。不清楚为什么要创建一个静态字段,通过静态搜索并尝试附加到它。这是不对的,这是不好的。如果您需要在类之间传递数据,那么请传递所需类的引用并从那里获取所需的属性,并且不要在那里创建一些不断挂在内存中的静态对象。
    6. public static- 再次静态,当这是特定对象的特定方法时。
    7. new ContextModel()- EF 足够智能,可以关闭其自身的上下文,您只需创建一次并将其存储为类的实例,该实例将在该类的整个生命周期内存在,而不是在每次调用时重新创建它并不断卸载它。
    8. .ToList();- 另一根拐杖。通过调用 EF,.To..()您可以将数据库中的所有数据卸载到内存中,其中可能有大量数据,从而使客户端的内存充满不必要的垃圾。你不应该这样做,或者你应该非常小心地这样做。
    9. 另外,从数据库获取数据的方法应该是异步的,我建议你朝这个方向思考。
    10. static CollectionViewSource- 静态(但我写过它),并且CollectionViewSource你不需要它在这个代码中。当您想要在 UI 级别过滤/分组元素时需要它,我在您的代码中没有看到它,但也许他们只是没有显示它......
    11. 相当粗糙的实现ICommand,我建议你寻找更好的东西,因为现在你写了很多不必要的东西和很多不必要的转换。一般来说,我推荐一个CommunityToolkit.MVVM可以用 1-2 行代码替换所有代码的库。
    12. Convert.ToInt32- 任何基类型都有方法Parse或TryParse,值得使用它们,而不是旧的转换器。 13.-MessageBox这是View层,根据MVVM的规则,VM层不应该知道有关View的任何信息,反之亦然。换句话说,您不应该在 VM 层使用 UI 组件,包括MessageBox。
    13. .Where(X => X.id_report == cnv1).FirstOrDefault();-Where额外的,相当简单.FirstOrDefault(x => x.id_report == cnv1)。
    14. var collection = reports;- 当您可以立即访问所需内容时,不清楚为什么要存储指向集合的链接。
    15. reports并且Reports- 这是两种不同的东西,在第一种情况下有一个公共字段没有任何特殊逻辑,在第二种情况下有一个公共属性,它具有set更新 UI 的重要逻辑。
    16. 命名。在 C# 中,通常按照严格的特定规则(即 CamelCase)来编写变量,不使用下划线,每个单词都大写。私有字段以小写字母开头。这是大家都遵守的标准。另外,给出更有意义的名称以使代码更易于理解。这是什么p?它是什么cnv1?现在您知道了,但是几年后您就能马上知道吗?不。因此,不要吝惜字母,立即给出正常且可理解的名称。好吧,此时我还要注意名字的重复。您的课程被调用ReportModel,在那里可以立即清楚它是什么Report。为什么房产证上到处都是_report?Report.Report一些...
    • 2

相关问题

  • 使用嵌套类导出 xml 文件

  • 分层数据模板 [WPF]

  • 如何在 WPF 中为 ListView 手动创建列?

  • 在 2D 空间中,Collider 2D 挂在玩家身上,它对敌人的重量相同,我需要它这样当它们碰撞时,它们不会飞向不同的方向。统一

  • 如何在 c# 中使用 python 神经网络来创建语音合成?

  • 如何知道类中的方法是否属于接口?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5