リンクがクリックされたときにシックボックスを呼び出しています。
<a href="createContact.aspx?placeValuesBeforeTB_=savedValues&TB_iframe=true&height=400&width=550&modal=true"
title="Add a new Contact" class="thickbox">Add a new Contact</a>
そして、サーバーボタンがクリックされると、このjavascript関数を呼び出して、jGrowl通知を表示します。
ScriptManager.RegisterClientScriptBlock(this, typeof(Page), Guid.NewGuid().ToString(), "$(function(){$.jGrowl('No Contact found: " + searchContactText.Text + "');});", true);
jGrowlがthickboxよりも最初に表示される場合を除いて、両方とも期待どおりに機能します。これにより、シックボックスが機能しなくなり、ページは通常のWebとして表示されます(シックボックスがなくなったかのように)。
誰かが何が起こっているのか知っていますか?
更新:これはマスターページのないテストページです:
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm2.aspx.cs" Inherits="RoutingPortal.Presentation.WebForm2" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script src="../Scripts/jquery-1.6.2.js" type="text/javascript"></script>
<script src="../Scripts/jquery-ui-1.8.16.custom.min.js" type="text/javascript"></script>
<script src="../Scripts/thickbox.js" type="text/javascript"></script>
<script src="../Scripts/jquery.jgrowl.js" type="text/javascript"></script>
<link href="../Scripts/css/jquery.jgrowl.css" rel="stylesheet" type="text/css" />
<link rel="stylesheet" href="~/CSS/thickbox.css" type="text/css" media="screen" />
</head>
<body>
<form id="form1" runat="server">
<asp:ScriptManager ID="ScriptManager1" runat="server">
</asp:ScriptManager>
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
<div>
<a href="createContact.aspx?placeValuesBeforeTB_=savedValues&TB_iframe=true&height=400&width=550&modal=true"
title="Add a new Contact" class="thickbox">Add a new Contact</a>
<asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click" />
</div>
</ContentTemplate>
</asp:UpdatePanel>
</form>
</body>
</html>
これはコードビハインドです:
namespace RoutingPortal.Presentation
{
public partial class WebForm2 : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
}
protected void Button1_Click(object sender, EventArgs e)
{
ScriptManager.RegisterClientScriptBlock(this.Page, typeof(Page), Guid.NewGuid().ToString(),
"$(function(){$.jGrowl('My Message');});", true);
}
}
}
UpdatePanelなしでテストしたところ、完全に機能しました。したがって、 UpdatePanelまたはコードビハインドから呼び出されたjGrowlとの相互作用の方法に間違いなく問題があります。
私はあなたの助けの人に大いに感謝します。
更新:この問題を簡単に特定できるデモプロジェクトも作成しました。これを手伝ってくれる人に送ってもかまいません。よろしくお願いします!
更新:@Rickによって提供されたソリューションも試し、jGrowlスクリプトの実行方法をコードビハインドから変更しました。
ScriptManager.RegisterStartupScript(this.Page, typeof(Page), Guid.NewGuid().ToString(),
"$.jGrowl('My Message');", true);
ただし、結果はまったく同じであるため、問題は解決しません。他のアイデアはありますか?どうぞよろしくお願いいたします。
更新:同じ問題に直面して、IE8とChromeでもこれを試しました。したがって、これはブラウザとは関係ありません。念のため。