我是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,我想迭代所有文本框并将数据插入数据库。
任何帮助都会被贬低。
提前致谢, 迪尼斯。
答案 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>
如果更改很小,您可以将文本字段值插入表记录中。