Kae Travis

Re-bind the GridView on the Parent Page after FancyBox close

Posted on by in ASP.Net
Tags:

I have a GridView with hyperlinks in some of the columns, which open up a new page in a FancyBox. FancyBox is a pretty cool lightbox alternative. Anyway, in the FancyBox page content you can make changes which will affect values in the parent page’s GridView. So when the FancyBox is closed, I needed to refresh the parent GridView. Here is how you can re-bind the GridView on the Parent Page after FancyBox close:

First I create a button, gave it an OnClick event, and used CSS to make it hidden:

<asp:Button ID="fancyBt" OnClick="fancyBt_Click" style="visibility: hidden; display: none;" runat="server" Text="Hidden - used to update GV on FancyBox close" />

FancyBox has a handy afterClose function which, unsurprisingly, gets calledafter the FancyBox is closed. What it does in here is call the click event of my hidden button:

$('.fancybox').fancybox({
'transitionIn': 'elastic',
'transitionOut': 'elastic',
'speedIn': 600,
'speedOut': 200,
'overlayShow': false,
'width': 1000,           // set the width
'height': 400,           // set the height
'type': 'iframe',       // tell the script to create an iframe
'scrolling': 'no',
afterClose: function () {
//refresh GV
document.getElementById('<%=fancyBt.ClientID%>').click();
}
});

and then of course, the code behind for the button click event should rebind the gridview!

protected void fancyBt_Click(object sender, EventArgs e)
{
//rebind GridView
}

 

Re-bind the GridView on the Parent Page after FancyBox close
Re-bind the GridView on the Parent Page after FancyBox close

Leave a Reply