web-dev-qa-db-ja.com

ASP.NetとC#の背後にあるコードからJQuery関数を呼び出す

プログラムでJQueryタブを無効にする必要があります。タブは更新パネル(Ajax)内にあり、更新パネルはASP.NETページにあります。コード:

<link type="text/css" rel="stylesheet" href="http://ui.jquery.com/testing/themes/base/ui.all.css" />

<script type="text/javascript" src="http://code.jquery.com/jquery-latest.js"></script>

<script type="text/javascript" src="http://ui.jquery.com/testing/ui/ui.core.js"></script>

<script type="text/javascript" src="http://ui.jquery.com/testing/ui/ui.tabs.js"></script>

<script type="text/javascript">

    $(document).ready(function(){
        $("#example").tabs();
    });


    function hidetabs(){
        $(document).ready(function(){
        $("#example").tabs();
        $('#example').data('disabled.tabs', [1, 2]);});
    }
</script>


<%@ Page Language="C#" MasterPageFile="~/any.Master" AutoEventWireup="true" Codebehind="anycode.aspx.cs"
    Inherits="anycode" %>

<asp:Content ID="Content1" ContentPlaceHolderID="ContentPlaceHolder1" runat="server">

<asp:UpdatePanel ID="UpdatePanel_Deal_Import" runat="server">
<ContentTemplate>
<div id="example">
<ul>
<li><a href="#fragment-1"><span>One</span></a></li>
<li><a href="#fragment-2"><span>Two</span></a></li>
<li><a href="#fragment-3"><span>Three</span></a></li>
</ul>
<div id="fragment-1">
<p>
First tab is active by default:</p>
<pre><code>$('#example').tabs();</code></pre>

<asp:Button ID="btn_Save" OnClick="btn_Save_Click" runat="server" Text="Save" Visible="False" CommandName="Save">
</div>

<div id="fragment-2">
Lorem ipsum dolor sit amet, consectetuer 
ut laoreet dolore magna aliquam erat volutpat.
</div>
<div id="fragment-3">
Lorem ipsum dolor sit amet, consectetuer 
aliquam erat volutpat.
</div>
</div>

      </ContentTemplate>
</asp:UpdatePanel>
</asp:Content>


Code behind:

protected void btn_Save_Click(object sender, EventArgs e)
{
//here I need to diable the panels.

}

関数btn_Save_Clickはページを送信しないため、Javascript/jquery hidetabs関数を呼び出しません。助けてくれてありがとう!!!

12
Ixtlan

私は次の方法を使用しており、私にとっては100%正しく動作します:

最初に私は関数を作成し、私のページの関数にjquery関数を書き込みます。

<script>
    function myFunction(params) {
        $.my_jquery(params...)
        ......
    }
</script>

次に、このコードをコントロールのイベントハンドラー(たとえば、ボタンをクリック)で使用しました。

protected void myButton(object sender, EventArgs e)
{
    .....
    ScriptManager.RegisterStartupScript(this.Page, this.GetType(), "tmp", "<script type='text/javascript'>myFunction(params...);</script>", false);
}

成功した

17
hamed aj

ポストバックするのではなく、client-sideアクションを持つボタンが必要なようです。

<asp:Button ID="Clickable" runat="server" text="Click me" OnClientClick="JavascriptCall();" />

さらに、jQueryは一般に下位互換性がありますが、jQueryの最新の.jsファイルを直接参照することはお勧めできません。代わりに、必要なバージョンをダウンロードし、既知のバージョンを直接参照できるようにサイトに静的に配置します。必要がない場合に、外部サイトのリソースの状態または可用性に依存関係を追加することは好ましくありません。

5
Chris Ballance

クリス、ありがとう

実際には、解決策の一部はjavascript関数を直接呼び出すことですが、クライアント側のコントロールを使用する代わりに、次のブログで説明されているように、UpdatePanelリクエストが終了したらJavaScriptを呼び出しました。

http://blog.jeromeparadis.com/archive/2007/03/01/1501.aspx

今私のコードは次のようになります:

<link type="text/css" rel="stylesheet" href="css/ui.all.css" />

    <script type="text/javascript" src="jquery-latest.js"></script>

    <script type="text/javascript" src="ui.core.js"></script>

    <script type="text/javascript" src="ui.tabs.js"></script>

    <script type="text/javascript">

    //enable tabs if a deal is selcted or saved.
    function EndRequestHandler(sender, args) {
        var rec_id = document.getElementById('<%=hidden_value.UniqueID %>').value;

        if (rec_id=="")
            hidetabs();
        else
            showtabs();
    }

    hidetabs();

    $(document).ready(function(){
        $("#rec_entry").tabs();
    });

    function hidetabs(){
        $(document).ready(function(){
        $("#rec_entry").tabs();
        $('#rec_entry').data('disabled.tabs', [1, 2, 3, 4, 5]);});
    }

    function showtabs(){
        $(document).ready(function(){
        $("#rec_entry").tabs();
        $('#rec_entry').data('disabled.tabs', []);});
    }

    Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler);

    </script>

    ...html code add the tabs... 

コードビハインド:

protected void btn_Save_Click(object sender、EventArgs e){

        .... code to save the new record ........  

        UpdatePanel_mypanel.Update();
    }

パネルが更新された後、EndRequestHandlerはフラグ(この場合は隠しフィールド)を評価し、タブを有効または無効にするJavaScript関数を呼び出します。

Endrequesthandlerは、私のJavaScriptに含まれている次の文のおかげで制御されます。

Sys.WebForms.PageRequestManager.getInstance().add_endRequest(EndRequestHandler);

私のプロジェクトにjavascriptファイルを含めるというあなたのアドバイスに従いました。再度、感謝します!

イクストラン

1
Ixtlan