【问题标题】:How do I dynamically add html elements to a page and access them in asp.net?如何动态地将 html 元素添加到页面并在 asp.net 中访问它们?
【发布时间】:2016-11-29 22:46:12
【问题描述】:

早安,

我已经尝试了一天多,以找出一种使用 Visual Studio 将元素动态添加到网页并访问其值的方法。我要么把整个事情复杂化了,要么我很笨,要么真的没有办法去做我想做的事情哈哈。 我正在尝试创建一个页面,该页面应该能够生成可能超过 100 个以下 html 项目集: 它基本上是用于创建多项选择测试的问答形式。有一个区域可以输入问题,然后是其他文本框,仅用于添加多项选择。还有一个按钮可以向答案区域添加额外的 2 个文本框(无论它们是创建并添加到表格行中的 div 中,还是在按下按钮时隐藏然后显示。)


[问题文本框]

[文本框][文本框][文本框][文本框] [向该行添加额外文本框的按钮(最多仅额外 2 个)]

[确认按钮提交文本框中的文本]


[添加上述元素的另一个副本的按钮(最多 100 个)]

我很想创建一个普通的表单(因为这可能是最简单的),但这需要在网络上工作。我知道跟踪所有这些内容可能是一场噩梦,但我想不出替代方案(好吧,我已经想到了替代方案,但它似乎更复杂)。我尝试了以下方法: 我尝试将 div 添加到表格单元格中以添加文本框,但之后我无法访问该 div。有没有办法做到这一点?如果我可以访问我使用 innerHtml 方法创建的元素,我或多或少会很好,但我在网上找不到任何东西。

QuestionContent.InnerHtml += "<table runat=\"server\" style=\"width: 100 %; \"><tr><td> Question " + _QuestionNum + " </td></tr><tr><td class=\"auto - style1\"><div id=\"divQ"+_QuestioNum+"\"></div></td></tr></table>"; 
//Might have an issue adding an element with runat=server, but this was the only way I could think of extracting a value that is created dynamically in C#.
                    ((System.Web.UI.HtmlControls.HtmlGenericControl)mainPanel.FindControl("divQ1")).InnerHtml = "<asp:TextBox ID=\"txtChoice1\" runat=\"server\">Choice1</asp:TextBox>"; 
    //Here I try to access the div created above. Unrelated: Also tried with a normal textbox, but I realise that creating an asp textbox here might cause issues.

我似乎无法访问我在 C# 中创建的任何内容。有没有更好的办法?放弃这个想法后,我尝试使用 javascript 创建元素。我仍然需要确定是否可以使用 javascript 将值传递给 C#,但我现在遇到了另一个问题。每当下面的代码运行时,元素就会出现,然后立即消失。这是asp.net的问题吗?谷歌结果不是很有帮助。

function addQuestion() {
if (numQuestions == limit) {
    alert('Maximum question limit reached. Consider breaking this test up into multiple tests.');
}
else {
    var newdiv = document.createElement('div');
    newdiv.setAttribute('id', 'divQ' + numQuestions);
    newdiv.innerHTML = '<table><tr><td> Question' + numQuestions + '</td></tr><tr><td>';
    for(var i=0;i<6;i++){
        newdiv.innerHTML += "<input type=\"text\" name=\"textBox"+i+"\">";
    }
    newdiv.innerHTML += '</td></tr></table>';
    numQuestions++;
    document.getElementById('divQuestionContent').appendChild(newdiv);       
}

}

但是,如果可以的话,我想避免使用 javascript。有没有更好的方法来创建这个页面?我只是做错了什么吗?任何帮助将不胜感激。

【问题讨论】:

  • 如果没有 JavaScript,您将无法获得动态内容
  • 我觉得如果你能拿起一些关于网络开发的书会更好。
  • 我肯定需要拿起一些关于网络开发的书哈哈。

标签: javascript c# html asp.net visual-studio


【解决方案1】:

我认为你是混合服务器和客户端代码。

1st)使用您的第一个已知必要字段创建 html 表单

2nd) Javascript 部分。用户在表单中添加字段(需要在 Javascript,客户端完成),检查这个答案: How add new hidden input fields to the form on submit

3rd) C# 部分。在表单请求中,您需要遍历所有 request.form 项目,因为您不知道它们有多少。这可以通过以下方式完成:

StringBuilder s = new StringBuilder();
foreach (string key in Request.Form.Keys)
{
    s.AppendLine(key + ": " + Request.Form[key]);
}
string formData = s.ToString();

【讨论】:

  • 谢谢!我去看看。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2011-07-27
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2022-11-17
  • 2020-03-22
相关资源
最近更新 更多