如何使用javascript添加动态创建的文本框值

时间:2011-05-02 12:13:13

标签: javascript asp.net html

请有人帮我解决这个问题;

我使用javascript动态创建了行。现在我的任务是添加文本框值。

由于它是动态创建的,因此所有文本框只有一个id或名称或类。

我从这个表中有一个固定的文本框。当用户输入第一个第一个文本框的值时,它应该进入该固定的文本框。

然后,如果他在动态创建的第二个文本框中输入了值(所有文本框只有相同的id),那么两个文本框值都应该被添加并在按下时显示在该固定文本框中。

希望你能理解我的问题。

如果可能的话,请帮助我。给我一些示例代码。此外,我的值将采用12:00,09:00之类的格式......

首先我需要相同ID的解决方案..如何解决这个id问题,以便我可以管理..帮助我

1 个答案:

答案 0 :(得分:0)

如果我正确找到你想要动态创建具有不同ID的文本框,然后想要读取服务器端的值。

查看以下代码

如果您在代码中遇到任何问题,请与我们联系。

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="DynamicTextboxJavascript.aspx.cs"
  Inherits="DynamicTextboxJavascript" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head id="Head1" runat="server">

  <script type="text/javascript">
function addElement() {
    var ni = document.getElementById('myDiv');
    var numi = document.getElementById('theValue');
    var num = (document.getElementById('theValue').value -1)+2;
    numi.value = num;
    var newdiv = document.createElement('div');
    var divIdName = 'my'+num+'Div';
    newdiv.setAttribute('id',divIdName);
    newdiv.innerHTML = '<input type="text"  name="TextBox'+num+'" value="TextBox'+num+'" >';    
    ni.appendChild(newdiv);
  } 


  </script>

  <title>Untitled Page</title>
</head>
<body>
  <form id="form1" runat="server">
      <asp:GridView ID="GridView1" runat="server">
      </asp:GridView>
      <div id="myDiv">
      </div>
      <input type="button" id="btnOfficial" value="Add Another TextBox" onclick="addElement();" />
      <input type="hidden" value="1" id="theValue" runat="server" />
      <asp:Button ID="btnSave" runat="server" OnClick="btnSave_Click" Text="Read" />
  </form>
</body>
</html>

using System;
using System.Data;
using System.Configuration;
using System.Collections;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;

public partial class DynamicTextboxJavascript : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{

}
protected void btnSave_Click(object sender, EventArgs e)
{

           ArrayList alForm = new ArrayList();
        //Because my textbox id is started
       // with 2 like(TextBox2,TextBox3.....
        for (int i = 2; i< Request.Form.Count - 2;i++)
        {
            string strId = "TextBox" + i.ToString();
            string strValue = Request.Form[strId].ToString();
            alForm.Add(strValue);
            strValue = "";


     }

  GridView1.DataSource = alForm;
  GridView1.DataBind();


}
}