领域层能否引用其他基础库中的UI控件?
黄国强 2011-11-28
首先说结论,结论是可以引用。理由如下:
1 从实用性角度分析:
看一个例子,比如界面上有一个CListBox控件,我们需要填充它,分别是两种写法:
1) 写法一,领域层没有对UI控件的引用
CStringArray ret;
pDomain->GetStringArray(ret);
for(int i=0;i<ret.GetSize();i++)
{
pListBox->AddString(ret[i]);
}
2) 写法二,领域层引用了UI控件
pDomain->FillListBox(pListBox);
显然第二种方法显得非常简洁。
2 从项目范围界定的角度分析:
担心的理由无非是领域层引向了UI控件,分层是不是就形同虚设了呢?答案是否定的。上例中CListBox是微软MFC库中的类,是个外部类,不在我们项目的范围中,所有可以自由引用。
下图表达了对分层与外部库的关系,图中明确的表达了分层与外部类库的关系。