2

我在数据库中有一个表,其中包含一堆不同的控件。在我的 Page_Init 方法中,我需要根据传入的 Session 变量加载适当的控件。有没有比使用一大堆 if..else 语句更好的方法来做到这一点?我有大约 15 到 20 种可能的不同场景,所以我不想写 20 个 if..else 语句。任何帮助是极大的赞赏!

标题为“值”的数据表,包含三列:(ID、名称、描述):

ID | Name | Description
-------------------
 1 | A    | First   
 2 | B    | Second   
 3 | C    | Third       

这是我的代码:

ControlOne c1;
ControlTwo c2;
ControlThree c3;

protected void Page_Init(object sender, EventArgs e)
{
    DataSet DS = Client.GetInformation(Session["Number"].ToString());
    DataRow DR = DS.Tables["Value"].Rows[0];

    if (DR["Name"].ToString() == "A" && DR["Description"].ToString() == "First")
    {
        c1 = (ControlOne)LoadControl("~/ControlOne.ascx");
        panel1.Controls.Add(c1);
    }
    else if (DR["Name"].ToString() == "B" && DR["Description"].ToString() == "Second")
    {
        c2 = (ControlTwo)LoadControl("~/ControlTwo.ascx");
        panel1.Controls.Add(c2);
    }
    else if (DR["Name"].ToString() == "C" && DR["Description"].ToString() == "Third")
    {
        c3 = (ControlThree)LoadControl("~/ControlThree.ascx");
        panel1.Controls.Add(c3);
    }
    else if... //lists more scenarios here..
}
4

3 回答 3

7

你可以这样做:

var controlsToLoad = new Dictionary<Tuple<string, string>, string>()
{
    { Tuple.Create("A", "First"), "~/ControlOne.ascx" },
    { Tuple.Create("B", "Second"), "~/ControlTwo.ascx" },
    { Tuple.Create("C", "Third"), "~/ControlThree.ascx" },
    ... 
};

var key = Tuple.Create(DR["Name"].ToString(), DR["Description"].ToString());
if (controlsToLoad.ContainsKey(key))
{
    Control c = LoadControl(controlsToLoad[key]);
    panel1.Controls.Add(c);
}

它比大量的 if..else 或 switch 块更紧凑,更容易阅读。

于 2013-05-30T20:47:05.317 回答
0

在我看来,您可以使用 switch 语句,并且只测试“名称”或“描述”。

于 2013-05-30T20:46:43.003 回答
0

您可以使用 switch 语句。

但是,有更好的方法。您的示例在 DB 表中有 ID、名称、描述。所以保持名称字段与用户控件名称相同,您可以这样做:

string controlName = dr["Name"];
c1 = LoadControl(string.Format("~/{0}.ascx", controlName));
panel1.Controls.Add(c1);

希望这可以帮助。

于 2013-05-30T20:50:31.123 回答