你调用的对象是空的。 - 控制集合

时间:2012-10-02 13:48:13

标签: c# asp.net razor textbox webmatrix

我是Asp.net和网站建设的新手,但我从Webmatrix网页开始,我实际上在我的网站上取得了很大的进步。 但我现在卡在一块剃刀代码中。我收到错误: 你调用的对象是空的。 排队: foreach(在Page.Controls中控制c1)

@{
    var db = Database.Open("DOM Coins");
    var codigo_campo_ID_unico=0;
    var valor_BC=0;


    if(IsPost){

        foreach(Control c1 in Page.Controls){
            foreach(Control c in c1.Controls){
            if (c.GetType().ToString() == "System.Web.UI.WebControls.TextBox"){
                if (c.ID=="BC_8"){
                   if (c.ID.Substring(0,2)=="BC"){
                      codigo_campo_ID_unico=int.Parse(c.ID.Substring(3,c.ID.Length-3));
                      valor_BC=int.Parse(Request[c.ID]);


                       db.Execute("UPDATE Coleccao SET Quantidade_BC=@valor_BC WHERE Id=@codigo_campo_ID_unico");
                   }
                }
            }
            }
        }
    }

}

我想这样做的原因是因为我正在创建文本框,每个文本框都有不同的ID,我想迭代所有文本框并将数据插入数据库。

任何帮助都会被贬低。

提前致谢, 迪尼斯。

2 个答案:

答案 0 :(得分:0)

在我看来,你使用的是asp.net网页,而不是MVC,对吗?你想呈现出来:

<input type="text" id="xxxx" />

作为标记,不直接添加元素。然后,在此之上,通过查询表单集检查对输入的ID的响应:

@{
   var ids = Request.Form.Keys.Where(i => i.StartsWith("BC"));
   //can process values here and store in dictionary, or process at render time
}

//Rerender textboxes - would have to base on ID's posted, or query again from DB

答案 1 :(得分:0)

下面的代码创建一个包含可变数量文本字段的表单,并读取将其存储到列表中的内容。

@{
    var num = 3; // number of text fields to create
    List<string> nText = new List<string>();
    if (IsPost)
    {
        for (int i = 0; i < num; i++)
        {
            var name = "txt" + i.ToString();
            nText.Add(Request.Form[name]);
        }
    }
}

<!DOCTYPE html>

<html lang="en">
    <head>
        <meta charset="utf-8" />
        <title></title>
    </head>
    <body>
        <form method="post">
            @for (int i = 0; i < num; i++)
            {
                var name = "txt" + i.ToString();
                <p>@name
                <input type="text" name="@name" />
                </p>
            }
            <input type="submit" />
        </form>
    </body>
</html>

如果更改很小,您可以将文本字段值插入表记录中。