Puoi forzare il postback con JavaScript collegando __doPostBack
a un evento.
function doClick(sender, e) {
__doPostBack(sender,e);
}
Domanda
Ho un pulsante che provoca la creazione di un popup:
<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>
Il pannello che è stato pop ha una gridview e quando viene premuto il pulsante un parametro SQL. :
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();
}
}
Il problema è che GridView non viene visualizzato perché non c'è postback sul server. Quando si aggiunge un pulsante ad Ajaxtolkit: modalpopupextender, il postback viene peccato. Come posso riprenderlo?
Soluzione
Puoi forzare il postback con JavaScript collegando __doPostBack
a un evento.
function doClick(sender, e) {
__doPostBack(sender,e);
}
Altri suggerimenti
Ciao utilizzo questo codice javascript per chiudere il popup e aggiornare la forma web principale
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)
Questo potrebbe aiutarti