获取动态添加的输入字段的内容

时间:2015-12-31 15:33:52

标签: javascript c# asp.net

当我点击按钮并尝试获取ASP.NET中新输入字段的内容时,我正在使用JavaScript向网页添加额外的输入字段,但我只能访问原始输入字段而不是用JavaScript创建的新的。

添加到的原始列表:

<ul class="add-event-list" id="eventList" runat="server">
    <li id="eventItemsList">
         <asp:TextBox name="event-info" TextMode="MultiLine" Columns="50" Rows="5" id="eventInfo" placeholder="Enter an Event..." runat="server"/>

         <label for="event-date" class="field-heading">Date</label>
         <asp:TextBox Type="date" name="event-date" id="eventDate" placeholder="Enter a Date..." runat="server"/>
     </li>
</ul>
<button class="btn add-event-btn" onclick="return false" >Add Event <span class="glyphicon glyphicon-plus"/></button>

按钮点击:

$('.add-event-btn').on('click', function () {
    var list = $('#eventItemsList').clone();
    $('.add-event-list').append(list);
});

在提交点击:

<button class="grey-btn" id="buttonSubmitHouse" onserverclick="buttonSubmitHouse_ServerClick" runat="server">Submit</button>

仅显示ul中的原始元素:

protected void buttonSubmitHouse_ServerClick(object sender, EventArgs e)
{
    foreach (Control item in eventList.Controls)
    {
        Control Test = item;
    }
}

1 个答案:

答案 0 :(得分:1)

您遇到此问题的原因是动态控件实际上并未在服务器上呈现。这就是为什么你不能遍历它们,服务器不知道它们存在。最简单的方法是实现Web服务。

当您拨打该服务时,您只需附加QueryString,然后执行所需的功能。所以从客户那里你可以做到:

$.ajax({
     type: '...',
     url: '...',
     dataType: 'json',
     success: (function (response) {
          // Do something with service response.
     })
});

根据您的技术,您可以点击控制器或使用通用Asp处理程序文件,因此您将锚定到传递给处理程序的HttpContext