private void rdAll_CheckedChanged(object sender, EventArgs e)
{ if (rdAll.Checked) { this.gvData.DataSource = GetDataSource("ALL"); } }
private void rdAudit_CheckedChanged(object sender, EventArgs e)
{ if (rdAudit.Checked) { this.gvData.DataSource = GetDataSource("Audit"); } }
private void rdNotAudit_CheckedChanged(object sender, EventArgs e)
{ if (rdNotAudit.Checked) { this.gvData.DataSource = GetDataSource("NotAudit"); } }
private void rdBilled_CheckedChanged(object sender, EventArgs e)
{ if (rdBilled.Checked) { this.gvData.DataSource = GetDataSource("Bill"); } }
private void rdUnBill_CheckedChanged(object sender, EventArgs e)
{ if (rdUnBill.Checked) { this.gvData.DataSource = GetDataSource("UnBill"); } }
当窗体的RadioButton控件比价多时,那么放眼望去,代码里面到处都是CheckedChanged事件、简直有如洪水泛滥。呵呵 其实我们可以委托来改进代码、这样可以让代码看起来简洁、逻辑清晰、代码量大量减少(当然这个例子不能够证明)。下面看看是如何改进的吧: 我们把所有RadioButton控件的CheckedChanged事件用同一个事件替换。
如下所示, 代码 private void RadioBtn_CheckedChanged(object sender, EventArgs e)
{
if (!((RadioButton)sender).Checked) return;
string filterValue = string.Empty;
switch (((RadioButton)sender).Tag.ToString())
{
case "ALL": filterValue = "ALL"; break;
case "Audit": filterValue = "Audit"; break;
case "NotAudit": filterValue = "NotAudit"; break;
case "Bill": filterValue = "Bill"; break;
case "UnBill": filterValue = "UnBill"; break;
}
this.gvData.DataSource = GetDataSource(filterValue);
}
这样处理那么就可以共用许多相同的代码(这个简单的例子没有体现)。让代码界面简明清晰不少! 文章出处:飞诺网(www.firnow.com):http://dev.firnow.com/course/3_program/cshapo/csharpjs/20100714/441757.html