加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 将逻辑放入ViewModel获取者中

发布时间:2020-12-15 19:35:57 所属栏目:百科 来源:网络整理
导读:您如何将Get-logic放入ViewModel的getter中?就像是: public class DummyViewModel{ public int Id { get; set; } private DummyObject myObject; public DummyObject MyObject { get { if (MyObject == null) { DummyRepository repo = new DummyRepositor
您如何将Get-logic放入ViewModel的getter中?就像是:

public class DummyViewModel
{
    public int Id { get; set; }

    private DummyObject myObject;

    public DummyObject MyObject
    {
        get
        {
            if (MyObject == null)
            {
                DummyRepository repo = new DummyRepository();
                myObject = repo.Get(Id);
            }
            return myObject;
        }
    }

}

这是不好的做法,还是完全没问题?通过在那里完成所有的get-logic,我发现我的控制器变得非常臃肿,但我真的很沮丧,我应该把它放在哪里……

我这样做的原因是我可以将ViewModel传递给不同类型的视图,并且只根据请求的属性执行必要的DB查找.

解决方法

将逻辑放入VM中的getter中没有任何问题 – VM的作用是将数据呈现给视图,并且它应该尽可能地“查看”(View不应该做太多(如果任何)在显示之前对数据进行整形的工作).

例如,我在我的VM中使用名为GetAvailableClients的属性,这将是View绑定到的属性之一.该特定getter的工作是过滤数据 – IOW提供从完整列表(也保存在VM中)中选择的减少的数据集,通常使用LINQ过滤数据,这意味着我已经放置了一些自定义逻辑在吸气器中.

我不喜欢的是你的方法的其余部分,如果属性没有被填充,它会转到存储库并获取数据本身.对我来说这是一个禁忌,该财产完全违反了single responsibility的原则,使财产负担过重.更何况,一旦你开始将该属性绑定到UI,这不是一个好习惯 – 突然你的应用程序将在用户执行操作时开始挂起,因为你的属性获取器已经被触发并且它决定调用数据库或web服务,并使更糟糕的是在UI线程上完成调用….它只是变得丑陋.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读