解析大型.NET ERP系统 查找与钻取

时间:2023-12-12 12:43:20

查找 Lookup

窗体是一个容器,也可以把TextBox,Button也看成是一个容器,可以往容器里面添加按钮。

参考下面的实现代码,给TextBox增加查找按钮。

var btn = new Button();
btn.Size = new Size(25, txtOutputPath.ClientSize.Height + 2);
btn.Location = new Point(txtOutputPath.ClientSize.Width - btn.Width, -1);
btn.Cursor = Cursors.Default;
btn.Text = "...";
btn.Click += new EventHandler(btn_Click); void btn_Click(object sender, EventArgs e)
{
using (FolderBrowserDialog dialog = new FolderBrowserDialog())
{
if (dialog.ShowDialog() == DialogResult.OK)
txtOutputPath.Text=dialog.SelectedPath;
}
}
 

这样就实现了增加查找按钮的功能。再向前进一步,我们将查找窗体中的内容设计为可编辑的查找,即可实现查找功能。

解析大型.NET ERP系统 查找与钻取

 

钻取 Drilldown

钻取是报表中产生的概念,由主表钻取到从表。在ERP系统中,支持数据的钻取。比如员工主文件中的部门,通过双击部门控件,可钻取到部门主文件,实现通过值的关联进入到它的编辑界面。

解析大型.NET ERP系统 查找与钻取

货币Ccy和付款条款Pay Terms控件值带有下划线,双击此下划线可跳转到它的编辑界面,上图中的例子就是分别进入货币主文件和付款条款主文件功能。

对WPF技术,参考下面的连接实现,TextDecorations.Underline Property

对WinForms技术,主要是为了设置控件的字体样式包含FontStyle.Underline样式,同时要捕获双击事件。

DrillDownEvent   DrillDown....
private void txtCcy_DoubleClick(object sender, EventArgs e)
{
if(DrillDown!=null)
DrillDown(this,e);
}

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }

对于Grid控件,捕获单元格Cell的双击事件DoubleClickCell,弹出主文件编辑窗体。

将要打开的功能和参数值封装成一个类型,做成自定义控件,可复用代码。

 

查找要与查询生成器结合才有威力,钻取需要与系统功能紧密集成,这两项功能为系统的可用性增色不少。

 

 

.csharpcode, .csharpcode pre
{
font-size: small;
color: black;
font-family: consolas, "Courier New", courier, monospace;
background-color: #ffffff;
/*white-space: pre;*/
}
.csharpcode pre { margin: 0em; }
.csharpcode .rem { color: #008000; }
.csharpcode .kwrd { color: #0000ff; }
.csharpcode .str { color: #006080; }
.csharpcode .op { color: #0000c0; }
.csharpcode .preproc { color: #cc6633; }
.csharpcode .asp { background-color: #ffff00; }
.csharpcode .html { color: #800000; }
.csharpcode .attr { color: #ff0000; }
.csharpcode .alt
{
background-color: #f4f4f4;
width: 100%;
margin: 0em;
}
.csharpcode .lnum { color: #606060; }