Вызовите функцию JQuery из кода позади (в стороне) ASP.Net и C #

Мне нужно программно отключить вкладки 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 HideTab. Спасибо за любую помощь !!!

12 голосов | спросил Ixtlan 17 FebruaryEurope/MoscowbTue, 17 Feb 2009 02:24:05 +0300000000amTue, 17 Feb 2009 02:24:05 +030009 2009, 02:24:05

3 ответа


0

Я использую следующий способ, и я работаю на 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);
}

успешно

ответил hamed aj 28 J000000Thursday11 2011, 17:29:20
0

Похоже, вам нужна кнопка, которая имеет действие на стороне клиента , а не кнопку, которая отправляет сообщения назад.

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

Кроме того, хотя jQuery обычно имеет обратную совместимость, не стоит напрямую ссылаться на последний файл jjuery .js. Вместо этого я бы скачал нужную вам версию и разместил бы ее статически на вашем сайте для прямой ссылки на известную версию. Не рекомендуется добавлять зависимость от состояния или доступности ресурса на внешнем сайте, когда в этом нет необходимости.

ответил Chris Ballance 17 FebruaryEurope/MoscowbTue, 17 Feb 2009 02:32:32 +0300000000amTue, 17 Feb 2009 02:32:32 +030009 2009, 02:32:32
0

Спасибо, Крис,

На самом деле да, частью решения является прямой вызов функции javascript, но вместо использования клиентского элемента управления я вызывал Javascript после завершения запроса UpdatePanel, как объясняется в следующем блоге:

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 (отправитель объекта, EventArgs e)         {

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

        UpdatePanel_mypanel.Update();
    }

после обновления панели EndRequestHandler оценивает флаг (в данном случае скрытое поле) и вызывает функцию Javascript, которая включает или отключает вкладки.

Обработчик конечных запросов контролируется благодаря этому предложению, включенному в мой JavaScript:

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

Я последовал вашему совету включить файлы javascript в мой проект. Еще раз спасибо!

Икстлан

ответил Ixtlan 18 FebruaryEurope/MoscowbWed, 18 Feb 2009 08:41:07 +0300000000amWed, 18 Feb 2009 08:41:07 +030009 2009, 08:41:07

Похожие вопросы

Популярные теги

security × 330linux × 316macos × 2827 × 268performance × 244command-line × 241sql-server × 235joomla-3.x × 222java × 189c++ × 186windows × 180cisco × 168bash × 158c# × 142gmail × 139arduino-uno × 139javascript × 134ssh × 133seo × 132mysql × 132