0

我是 ASP.NET AJAX 的新手,我正在尝试获取一个状态文本框/按钮,以允许用户在没有回发的情况下更新状态。我在母版页上有一个脚本管理器标签,“enablepartialrendering”设置为“true”。我在内容页面上也有一个 updatepanel 标签。当我尝试这个时,页面回发并且没有任何反应。我究竟做错了什么?我正在使用 ASP.NET 3.5 / C#。谢谢。

母版页在表单标记下方有以下脚本标记:

<asp:ScriptManager ID="ScriptManager1" runat="server" EnablePartialRendering="true">
    </asp:ScriptManager>

在页面的某处存在一个 ContentPlaceHolder:

<asp:ContentPlaceHolder ID="ContentCenter" runat="server">
                </asp:ContentPlaceHolder>

ContentPlaceHolder 的关联内容标签如下所示:

<asp:Content ContentPlaceHolderID="ContentCenter" runat="server">
    <div class="divContainer">
        <div class="divContainerBox">
            <div class="divContainerTitle">
                Network Activity</div>
            <div class="divContainerRow">
                <asp:Panel ID="pnlStatusUpdate" runat="server">
                    <asp:TextBox Width="400" Height="50" Style="font-size: 9px; padding-left: 0px; padding-right: 0px;"
                        ID="txtStatusUpdate" runat="server"></asp:TextBox>
                    <br />
                    <asp:Button Style="font-size: 9px; padding-left: 0px; padding-right: 0px;" ID="BtnAddStatus"
                        runat="server" Text="Add" /><br />
                    <asp:Repeater ID="repFilter" runat="server">
                        <ItemTemplate>
                            <asp:Label ID="lblMessage" runat="server" Text='<%# ((Alert)Container.DataItem).Message  %>'></asp:Label>
                        </ItemTemplate>
                        <SeparatorTemplate>
                            <hr />
                        </SeparatorTemplate>
                    </asp:Repeater>
                    <asp:Label ID="lblMessage" runat="server"></asp:Label>
                </asp:Panel>
            </div>
        </div>
    </div>
</asp:Content>

这是服务器方法。它不返回任何内容 - 它将数据发送到“SaveStatusUpdate”到数据库。下次页面回发时,会出现新的更新。我想要的是没有回发,并且在单击状态更新按钮时显示输入的输入文本(以及朋友可能输入的任何文本)。

protected void BtnAddStatusClick(object sender, EventArgs e)
        {
            var su = new StatusUpdate
             {
                 CreateDate = DateTime.Now,
                 AccountId = _userSession.CurrentUser.AccountId,
                 Status = txtStatusUpdate.Text
             };

            _statusRepository.SaveStatusUpdate(su);
            _alertService.AddStatusUpdateAlert(su);

        }

我猜有人可能会问“AddStautsUpdateALert”方法是什么样的,所以就在这里。“_alertMessage”是状态更新。如何使用 AJAX 显示它?

public void AddStatusUpdateAlert(StatusUpdate statusUpdate)
        {
            _alert = new Alert
                        {
                            CreateDate = DateTime.Now,
                            AccountId = _userSession.CurrentUser.AccountId,
                            AlertTypeId = (int) AlertType.AlertTypes.StatusUpdate
                        };
            _alertMessage = "<div class=\"AlertHeader\">" + GetProfileImage(_userSession.CurrentUser.AccountId) +
                           GetProfileUrl(_userSession.CurrentUser.UserName) + " " + statusUpdate.Status + "</div>";
            _alert.Message = _alertMessage;
            SaveAlert(_alert);
            SendAlertToFriends(_alert);

        }
4

1 回答 1

1

更新面板仍然发布到服务器——它们只是不将整个 HTML 文档返回给客户端。相反,它们会返回包含在您的页面中的部分<asp:UpdatePanel>并替换其内容。

只要BtnAddStatus在更新面板内,您启用了部分页面渲染,并且您没有禁用更新面板触发器,单击该按钮应该会触发您的服务器端事件(它不会直接调用该AddStatusUpdateAlert方法)。

有关详细信息,请参阅“使用 ASP.NET AJAX 了解部分页面更新”。(以前在同一个站点上有一篇很棒的文章,带有非常有用的图表,但它已经消失了。)

于 2010-07-02T20:21:07.540 回答