我的表单中有一个 ProductName 属性。我在编译代码时收到警告。
FormInventory.ProductName
隐藏了继承的成员“System.Windows.Forms.Control.ProductName”
。如果打算隐藏,请使用 new 关键字。
下面是我的代码
public partial class FormInventory : Form, IInventoryView
{
public FormInventory()
{
}
public string ProductName
{
get { return this.textProductName.text; }
set { this.textProductName.text = value; }
}
}
textProductName
是一个文本框。
我知道 ProductName
隐藏了基类的属性 Forms.Control.ProductName
。我的问题是
是否可以在不重命名我的
FormInventory.ProductName
属性的情况下抑制警告我目前处于开发初期,如果我用
new
修饰符隐藏这个属性,在发布产品的时候会不会有什么问题,因为基础属性Forms.Control.ProductName
返回包含控件的程序集的产品名称。我的FormInventory.ProductName
返回用户输入的值。我们将在哪里使用此
Forms.Control.ProductName
,因为我以前从未使用过它。
我已经搜索并找到了类似的问题
这些问题并没有解决我的问题,但帮助我理解了警告的原因。
最佳答案
如果 ProductName 是您打算在表单上显示的表单字段,为什么不将属性的所有字段抽象为一个单独的 Product 实体。这应该可以简化您的应用程序的维护(并使其更符合 MVC/MVVM 等模式),例如
public class Product
{
public string ProductName{ get; set; }
public int ProductSize{ get; set; }
// etc
}
public partial class FormInventory : Form
{
public FormInventory()
{
}
public Product Product
{
get;
set;
}
}
编辑:
IMO,Rod Cerata 的博客呈现的架构看起来不错,但我相信通过为您的员工封装“ViewModel”可以改进它。
看看 EmployeePresenter.cs - 你会得到很多像这样的重复抓取代码:
_model.EmployeeID = _view.EmployeeID;
_model.Lastname = _view.Lastname;
_model.Firstname = _view.Firstname;
_model.EmployeeType = _view.EmployeeType;
_model.Salary = _view.Salary;
_model.TAX = _view.TAX;
IMO 将通过创建一个新的 EmployeeViewModel 类来改进(它或多或少与 EmployeeModel 相同,加上任何“屏幕”特定字段,例如标题、“模式”(编辑、新建、只读等),然后使用像 AutoMapper 这样的工具,这将减少上面的代码。
关于c# - ProductName 隐藏 System.Windows.Forms.Control.ProductName,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11733253/