将逻辑放在ViewModel geters中

Yng*_*sen 3 c# model-view-controller asp.net-mvc

您如何将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;
        }
    }

}
Run Code Online (Sandbox Code Playgroud)

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

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

slu*_*ter 10

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

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

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