Você pode forçar o postback com JavaScript anexando __doPostBack
para um evento.
function doClick(sender, e) {
__doPostBack(sender,e);
}
Pergunta
Eu tenho um botão que faz com que um pop -up seja criado:
<ItemTemplate>
<asp:Button ID="viewHoursButton" runat="server" Text="View Hours" OnClick="viewHoursButton_OnClick" />
<ajaxToolkit:ModalPopupExtender ID="viewHoursPopup" runat="server"
TargetControlID="viewHoursButton"
PopupControlID="viewHoursPanel"
CancelControlID="closeInfoPanelButton2"
DropShadow="true">
</ajaxToolkit:ModalPopupExtender>
<asp:Panel ID="viewHoursPanel" runat="server" CssClass="infoPanel">
//content of panel including gridview
</asp:Panel>
</ItemTemplate>
O painel que o Pop's Up possui um GridView e quando o botão é pressionado, um parâmetro SQL é passado. :
protected void viewHoursButton_OnClick(object sender, EventArgs e)
{
Button btn = sender as Button;
GridViewRow row = btn.NamingContainer as GridViewRow;
SqlDataSource6.SelectParameters["nonScrumStoryId"].DefaultValue = storyGridView.DataKeys[row.RowIndex].Values[0].ToString();
var viewHoursGridView = storyGridView.FindControl("viewHoursGridView") as GridView;
if (viewHoursGridView != null)
{
viewHoursGridView.DataBind();
}
}
A questão é que o Gridview não está sendo exibido porque não há postagem no servidor. Quando você adiciona um botão ao Ajaxtoolkit: ModalPoPuPextender, o postback é penteado. Como faço para recuperá-la?
Solução
Você pode forçar o postback com JavaScript anexando __doPostBack
para um evento.
function doClick(sender, e) {
__doPostBack(sender,e);
}
Outras dicas
Oi eu uso este código javascript para fechar o pop -up e atualizar o pai da web fort
Dim str_java As String = "<script language='javascript'>"
str_java += (" window.onunload = refreshParent; ")
str_java += (" function refreshParent() { ")
str_java += (" window.self.location.reload(true); } ")
str_java += (" window.close(); ")
str_java += ("</script>")
ScriptManager.RegisterStartupScript(Me, GetType(Page), "cerrarpagina", str_java, False)
Isso pode te ajudar