我正在开发一个实用程序,它将为“Filters”提供一个接口,该接口具有该接口的许多实现。接口的一部分将返回Control类型的对象,该对象将在UI中用于操作过滤器。
我希望能够要求返回的控件还实现另一个接口,以便我可以执行诸如请求控件写回创建它们的对象之类的事情。
现在我的代码看起来像:
public interface IFilter
{
Control Control();
}
我想要像:
public interface IFilterControl
{
...
}
public class FilterControl : Control, IFilterControl{}
public interface IFilter
{
...
FilterControl Control();
}
上述方法不起作用,因为FilterControl实际上并没有实现IFilterControl。
如果以上内容不够明确,请尝试想象虚构关键字“implmenting”如何在下面工作
public interface IFilterControl
{
IFilter Filter{get;}
}
public interface IFilter
{
Control implmenting IFilterControl Control();
}
public interface FilterImpl : IFilter
{
Control implmenting IFilterControl Control(){
return new FilterControlImpl(this);
}
}
public partial class FilterImplControl : UserControl, IFilterControl
{
FilterImpl filter;
public FilterImplControl(FilterImpl filter)
{
this.filter = filter;
}
public IFilter Filter{get{return filter;}}
}
FilterImpl a_filter = GetAFilter();
Control implmenting IFilterControl ctl = a_filter;
panel.Controls.Add(ctl);
FilterImpl the_filter_indirectly = ctl.Filter;
答案 0 :(得分:5)
可能想看看使用泛型。他们会让你对类型施加限制。
public interface IFilter<T> where T : Control
{
T Control { get; set; }
T ControlMethod();
}
where子句是一种通用约束,并且要求T始终是Control类型。它也适用于接口。这样,您就知道这些方法或属性始终是Control的衍生物,这些期望将出现在intellisense中。
EDIT 哦,我突然意识到,如果你愿意的话,你可以单独使用该方法。
interface IFilter
{
T Control<T>() where T : Control;
}