停止双回发

时间:2009-09-17 14:39:37

标签: c# asp.net javascript vb.net updatepanel

这是我正在做的事情。我在我创建的gridview的标题行中创建了两个按钮。按钮是+ page和-page。当-page被点击时,我删除了分页,所有数据都在页面下方,-page消失,+页面就在那里。

这是我的问题当我点击+页面时,我必须进行双重回发,因为我的数据的一行会消失。我将在下面提供代码。我该怎么做才能解决这个问题?

Dim bttnrempag As New Button
    bttnrempag.ID = "bttnrempag"
    bttnrempag.Text = "      Paging"
    bttnrempag.CssClass = "bttnMinEG"
    bttnrempag.ValidationGroup = "alone"
    bttnrempag.Attributes.Add("onclick", "return Paging('1')")

    Dim bttnallowpag As New Button
    bttnallowpag.ID = "bttnallowpag"
    bttnallowpag.Text = "      Paging"
    bttnallowpag.ValidationGroup = "alone"
    bttnallowpag.CssClass = "bttnAddEG"
    bttnallowpag.Attributes.Add("onclick", "return Paging('0')")

---------------------如何添加按钮------------------ ------------------------

    Dim row As New GridViewRow(-1, -1, DataControlRowType.Separator, DataControlRowState.Normal)
    row.Cells.Add(cell)
    cell.Controls.Add(bttnrempag) '36
    cell.Controls.Add(bttnallowpag)

-------------------------------------------- --------------------------------------------

function Paging(remove) {
    var gridView = $get('<%=Gridview1.ClientID %>');
    var txt2 = $get('<%=TextBox2.ClientID %>');
    if (remove == '1') {
        txt2.value = '1';
        __doPostBack('<%=UpdatePanel1.ClientID %>', '');
        return false;
    }
    else {
        txt2.value = '0';
        __doPostBack('<%=UpdatePanel1.ClientID %>', '');
        return false;
    }

被修改

<asp:UpdatePanel ID="UpdatePanel1" runat="server">
    <ContentTemplate >
        <asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
        <asp:GridView ID="GridView1" runat="server" AllowPaging="True" 
            AutoGenerateColumns="False" BackColor="White" BorderColor="#E7E7FF" 
            BorderStyle="None" BorderWidth="1px" CellPadding="3" 
            DataSourceID="SqlDataSource1" Font-Names="Comic Sans MS" Font-Size="XX-Small"
            Caption = '<table border="" width="100%" cellpadding="3" cellspacing="0" bgcolor="#4A3C8C"><tr><td style = "font-size:X-large;font-family:Arial CE;color:White"><b>Ordering/Receiving Log</u></td></tr></table>' 
            Font-Bold="True" PageSize="15" >
            <RowStyle BackColor="#E7E7FF" ForeColor="#4A3C8C" />

            <Columns>
                      Bound Data
            </Columns>
            <FooterStyle BackColor="#B5C7DE" ForeColor="#4A3C8C" />
            <PagerStyle BackColor="#E7E7FF" ForeColor="#4A3C8C" HorizontalAlign="Right" />
            <EmptyDataTemplate>
            <head>
                <meta http-equiv="refresh" content="5;URL=/Corporate_newpo/ReceivingLog.aspx?">
            </head>
                <script type="text/javascript" >
                    var count = 6;
                    var counter = setInterval("timer()", 1000); //1000 will  run it every 1 second

                    function timer() {
                        count = count - 1;
                        if (count <= 0) {
                            clearInterval(counter);
                            //counter ended, do something here
                            return;
                        }
                        $get("timer").innerHTML = "The Table will Reload in " + count + " secs";
                    }
                </script>
                <asp:Label ID="Label1" runat="server" Font-Bold="True" Font-Size="Large" 
                    ForeColor="#993333" Text="No Data was Found for the Selected Filter"></asp:Label><br /><br />
               <span id="timer" style="font-size:medium;color:blue"></span>
            </EmptyDataTemplate>
            <SelectedRowStyle BackColor="#738A9C" Font-Bold="True" ForeColor="#F7F7F7" />
            <HeaderStyle BackColor="#4A3C8C" Font-Bold="True" ForeColor="#F7F7F7" />
            <AlternatingRowStyle BackColor="#F7F7F7" />
            <PagerTemplate>
                <small 12px""="" style="font-size:xx-small; padding-right">Go To Page</small>
                <asp:DropDownList ID="ddlPageSelector" runat="server" AutoPostBack="true" 
                    Font-Size="XX-Small" Height="19px" Width="36px">
                </asp:DropDownList>
                <asp:ImageButton ID="btnFirst" runat="server" CommandArgument="First" 
                    CommandName="Page" SkinID="pagefirst" />
                <asp:ImageButton ID="btnPrevious" runat="server" CommandArgument="Prev" 
                    CommandName="Page" SkinID="pageprev" />
                <asp:ImageButton ID="btnNext" runat="server" CommandArgument="Next" 
                    CommandName="Page" SkinID="pagenext" />
                <asp:ImageButton ID="btnLast" runat="server" CommandArgument="Last" 
                    CommandName="Page" SkinID="pagelast" />
            </PagerTemplate>
            </asp:GridView>
        </ContentTemplate> 
    </asp:UpdatePanel>

正如你所看到的,当一个或另一个被击中时,我将一个文本框设置为某个值,然后我对我在该Updatepanel中的Gridview进行部分回发。

7 个答案:

答案 0 :(得分:2)

我怀疑是因为你调用了“__doPostBack”方法。按钮的正常默认点击行为将执行异步回发,您可能会执行另一次。尝试删除它,看看它是怎么回事。

答案 1 :(得分:1)

你能尝试在RowDataBound事件声明中的按钮上放置Click属性吗?

干杯。

答案 2 :(得分:1)

尝试更改&lt; asp:ImageButtons&gt;要成为常规HTML&lt; img&gt;标签。

我遇到过这种事情,之前很难诊断,甚至更难解释。有关可能有所帮助的错误行为,请参阅herehere。如果你有&lt; img&gt;带有空白src属性的标签,然后我提供的超链接可能解释了问题。如果您没有任何空白&lt; img&gt;标签然后继续阅读我的工作。

在我的具体情况下,它只发生在某些服务器(某些客户端站点)而不是其他服务器上,因此我找不到代码的任何具体问题。我的解决方法是更改​​我的&lt; asp:ImageButtons&gt;常规&lt; img&gt;使用javascript单击事件来调用函数来执行回发的标记,就像你的Paging()函数一样。

出于某种原因,我发现了一个&lt; asp:ImageButton&gt;与客户端onclick返回事件:确认('你确定吗?');如果confirm()返回false,则会停止回发,但是在手动调用__doPostBack之后,在Paging()函数中返回false会导致页面无法一直停止返回。

答案 3 :(得分:1)

请查看页面上呈现的html:

每次出现

<img src=""/>

对于某些浏览器,可能会发生双重回发......

可以解决此问题,为每个按钮设置默认的空白图像

<asp:ImageButton ImageUrl="~/Images/blank.gif"...>

无论如何,如果您在Immediate Window内放置一个断点并允许识别导致回发的控件

,则可以在Page_Load中输入此命令
Page.Request.Params["__EVENTTARGET"];

答案 4 :(得分:0)

试试这个,(我不知道你为什么使用javascript):

bttnrempag.onclick += bttnrempag_Click; 

protected void bttnrempag_Click(object sender, EventArgs e)
{
    //handle the removal of paging or whatever.
}

答案 5 :(得分:0)

您必须为ImageButtons提供图像。否则,呈现的HTML将生成<img src="">标记,并且在呈现此标记时,它将导致回发。试试吧。

答案 6 :(得分:0)

我找到了一个很好的解决方案。它确实附加了它自己的处理程序,但我想这也可以修复。

using System.Linq;

private void GridView_OnItemDataBound(object sender, GridViewRowEventArgs e)
{
    if (e.Row.RowType == DataControlRowType.DataRow)
    {
        var buttons = e.Row.Cells.OfType<DataControlFieldCell>().SelectMany(item => item.Controls.OfType<ImageButton>());
        foreach (ImageButton imageButton in buttons)
        {
            var argument = imageButton.CommandName + "$" + imageButton.CommandArgument;
            imageButton.OnClientClick = this.Page.ClientScript.GetPostBackClientHyperlink(this.GridView, argument) + "; return false;";
        }
    }
}