Как открыть диалоговое окно jQuery UI на странице с главной страницей? - PullRequest
1 голос
/ 21 ноября 2011

Я хочу открыть диалог пользовательского интерфейса jQuery со страницы asp.net с главной страницей. На странице внутри главной страницы код работает нормально, но с главной страницей не работает.

Код:

<%@ Page Title="" Language="vb" AutoEventWireup="false"   MasterPageFile="~/privado/master/interior.master" CodeBehind="WebForm3.aspx.vb" Inherits="ProyectoDemo.WebForm3" %>
<asp:Content ID="Content1" ContentPlaceHolderID="headInterior" runat="server">
    <link type="text/css" href="Styles/jquery-ui-1.8.16.custom.css"    rel="stylesheet" />  
    <link href="Styles/addhunters.css" rel="stylesheet" type="text/css" />
    <script type="text/javascript" src="js/jquery-1.6.2.min.js"></script>
    <script type="text/javascript" src="js/jquery-ui- 1.8.16.custom.min.js"></script>
    <style type="text/css">
        /*demo page css*/
        body{ font: 62.5% "Trebuchet MS", sans-serif; margin: 50px;}
        .demoHeaders { margin-top: 2em; }
        #dialog_link {padding: .4em 1em .4em 20px;text-decoration:  none;position: relative;}
        #dialog_link span.ui-icon {margin: 0 5px 0 0;position: absolute;left: .2em;top: 50%;margin-top: -8px;}
        ul#icons {margin: 0; padding: 0;}
        ul#icons li {margin: 2px; position: relative; padding: 4px 0; cursor: pointer; float: left;  list-style: none;}
        ul#icons span.ui-icon {float: left; margin: 0 4px;}
    </style>    
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="contenidoInterior" runat="server">
    <script type="text/javascript">
        $(function () {
            // Dialog      
            $('#dialog').dialog({
                autoOpen: false,
                width: 600,
                height: 400,
                buttons: {
                    "Ok": function () {
                        $(this).dialog("close");
                    },
                    "Cancelar": function () {
                        $(this).dialog("close");
                    }
                }
            });
            // Dialog Link
            $('#Boton').click(function () {
                $('#dialog').dialog('open');
                return false;
            });
        });
    </script>

    <div id="uno">
        <h2 class="demoHeaders">Dialog</h2>        
        <asp:TextBox ID="TextBox1" runat="server" Text="prueba" ></asp:TextBox>
        <p><a href="#" id="dialog_link" class="ui-state-default ui-corner-all"><span class="ui-icon ui-icon-newwin"></span>Open Dialog</a></p>              
        <asp:LinkButton ID="Boton" runat="server">LinkButton</asp:LinkButton>
        <asp:Button ID="Button1" runat="server" Text="Button" />
        <!-- ui-dialog -->
        <div id="dialog" title="Dialog Title">
            <p>Dialog text</p>            
        </div>  
    </div>

Я думаю, проблема в том, как обратиться к «диалогу» внутри заполнителя. Я пробовал несколькими способами, но не нашел решения.

Кто-нибудь знает, как решить эту проблему?

Заранее спасибо!

Хавьер

Ответы [ 5 ]

1 голос
/ 21 ноября 2011

Есть несколько вещей, которые вам нужно учитывать:

  1. Добавьте следующий код в отдельный файл common.js и добавьте его ссылку на главную страницу:

window["common"] = {
    liveDialog: function(btnId) {
         $(btnId).live(click,common.showDialog);
         return false;
    },
    showDialog() : function(){
         $('#dialog').dialog({
                autoOpen: false,
                width: 600,
                height: 400,
                buttons: {
                    "Ok": function () {
                        $(this).dialog("close");
                    },
                    "Cancelar": function () {
                        $(this).dialog("close");
                    }
                }
            });

    }

}
  1. Добавить следующий метод на главную страницу:
public void RegisterDialog(clientBtnId)
{
    this.page.ClientScript.RegisterStartupScript(this.Page.GetType(),"__registerDialg","common.liveDialog('"+clientBtnId+"');",true);
}
  1. Из вашей страницы содержимого приведите this.MasterPage к фактическому имени класса вашей главной страницы и передайте идентификатор клиента вашей кнопки в RegisterDialog.

- отредактированный пример -

Например, имя класса вашей главной страницы - CustomSiteMaster, вы можете написать ((CustomSiteMaster)this.Master).RegisterDialog(button1.ClientID); - конец редактирования -

Будет работать без проблем

0 голосов
/ 22 ноября 2011

У меня есть решение для "мистерии".Проблема очень проста.Ссылки на файлы .js jQuery-UI находятся в заполнителе Conten1, я поместил эти две строки в заполнитель Conten2, этот контент имеет функцию javascript для открытия диалога.

Полный и рабочий кодследующее:

<%@ Page Title="" Language="vb" AutoEventWireup="false"   MasterPageFile="~/privado/master/interior.master" CodeBehind="WebForm3.aspx.vb"   Inherits="ProyectoDemo.WebForm3" %>
<asp:Content ID="Content1" ContentPlaceHolderID="headInterior" runat="server">
    <link type="text/css" href="Styles/jquery-ui-1.8.16.custom.css"    rel="stylesheet" />  
    <link href="Styles/addhunters.css" rel="stylesheet" type="text/css" />
    <%--<%@ MasterType  VirtualPath="~/privado/master/Interior.master"%>--%>
    <style type="text/css">
        /*demo page css*/
        body{ font: 62.5% "Trebuchet MS", sans-serif; margin: 50px;}
        .demoHeaders { margin-top: 2em; }
        #dialog_link {padding: .4em 1em .4em 20px;text-decoration:    none;position: relative;}
        #dialog_link span.ui-icon {margin: 0 5px 0 0;position:   absolute;left: .2em;top: 50%;margin-top: -8px;}
        ul#icons {margin: 0; padding: 0;}
        ul#icons li {margin: 2px; position: relative; padding: 4px 0;   cursor: pointer; float: left;  list-style: none;}
        ul#icons span.ui-icon {float: left; margin: 0 4px;}
    </style>    
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="contenidoInterior" runat="server">
    <script type="text/javascript" src="js/jquery-1.6.2.min.js"></script>
    <script type="text/javascript" src="js/jquery-ui-   1.8.16.custom.min.js"></script>
    <script type="text/javascript">
        $(document).ready(function () {
            alert('hola');
            $('#dialog').dialog({
                autoOpen: false,
                width: 600,
                height: 400,
                buttons: {
                    "Ok": function () {
                        $(this).dialog("close");
                    },
                    "Cancelar": function () {
                        $(this).dialog("close");
                    }
                }
            });

            $('#MainContent_contenidoInterior_Boton').click(function () {
                $('#dialog').dialog('open');
                return false;
            });
        });               
    </script>

    <div id="uno" >
        <h2 class="demoHeaders">Dialog</h2>        
        <asp:TextBox ID="TextBox1" runat="server" Text="prueba" ></asp:TextBox>
        <p><a href="#" id="dialog_link" class="ui-state-default ui-corner-all"><span class="ui-icon ui-icon-newwin"></span>Open Dialog</a></p>              
        <asp:LinkButton ID="Boton" runat="server">LinkButton</asp:LinkButton>
        <asp:Button ID="Button1" runat="server" Text="Button" />
        <!-- ui-dialog -->
        <div id="dialog" title="Dialog Title">
            <p>Dialog text</p>            
        </div>  
    </div>

Спасибо за ваши ответы.

Хавьер

0 голосов
/ 21 ноября 2011

Пользовательский интерфейс jQuery не загружается, поскольку в атрибуте src есть дополнительный пробел:

 <script type="text/javascript" src="js/jquery-ui- 1.8.16.custom.min.js"></script>

Просто измените его на:

<script type="text/javascript" src="js/jquery-ui-1.8.16.custom.min.js"></script>

И пользовательский интерфейс jQuery может нормально загружатьсяи вы перестанете получать "the object does not support this property or method" сообщений.

0 голосов
/ 21 ноября 2011

Чтобы найти какой-либо элемент управления в заполнителе содержимого, используйте следующий синтаксис:

$('#ContentPlaceHolderId_ControlId')
0 голосов
/ 21 ноября 2011

Добавьте к свойству LinkButton OnClientClick, как показано ниже:

<asp:LinkButton ID="Boton" runat="server" 
OnClientClick="$('#dialog').dialog('open'); return false;" >LinkButton</asp:LinkButton>

Также, если вы хотите выбрать серверный элемент управления по id, используйте следующий синтаксис селектора:

$("#<%= ControlID.ClientID %>")
...