繁体   English   中英

如何在C#中编辑/更新集合中的数据

[英]How to Edit/Update Data in Collection in C#

我的C#代码中有一个集合

private ObservableCollection<UserForms> _userForms = 
    new ObservableCollection<UserForms>();

public ObservableCollection<UserForms> UserForms { get { return _userForms; } }

我正在用4个值填充收藏

foreach (DataRow dr in DataTable.Rows)
{
                    UserForms.Add(new UserForms()
                    {
                        FormID = Convert.ToInt32(dr["FormID"]),
                        FormName = dr["FormName"].ToString(),
                        FromSyName = dr["FormSyName"].ToString(),
                        Visibility = false,
                        RoleAdd=false,
                        RoleEdit=false,
                        RoleDelete=false
                    });
}

我在Form_Load()事件中填写此内容

现在我要更新

Visibility = true,
RoleAdd=true,
RoleEdit=true,
RoleDelete=true

在集合中的指定行中。

您只需要执行以下操作:

UserForms[0].Visibility = true;

其中“ [0]”是索引。

如果您的ObservableCollection是可枚举的(通常是哪个集合),则可以使用如下所示的foreach循环:

foreach(UserForms uf in UserForms)
{
    if (uf.FormID > 10)
        uf.Visibility = true;
}

在上面的代码中,我更改了FormID大于10的行的可见性。

看起来您需要过滤掉一些项目然后进行更新。

foreach(UserForms uf in UserForms.Where(i=>i.FormName == "FormName"/*put your filtering criteria here*/))
{
    uf.Visibility = true;
    // Set all needed properties here
}

您要访问集合的实例。

_userForms.ToList().ForEach((f) => f.Visibility = true); 

或者,如果您知道索引并想更新单个项目。

 _userForms[index].Visibility = true;

或用于多个过滤器项目

 var filterColl = coll.Where((c)=> c.FormName.StartsWith("A"));
 filterColl.ToList().ForEach((f) => f.Visibility = true); 

希望这可以帮助..

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM