ModalPopupExtender: перетаскивание диалогового окна приводит к ошибке «scrollleft равен нулю или не является объектом» - PullRequest
1 голос
/ 08 января 2010

Я использую элемент управления ModalPopupExtender для отображения модального всплывающего диалогового окна при нажатии кнопки. Проблема заключается в том, что перетаскивание диалогового окна приводит к ошибке «scrollleft равен нулю или не является объектом».

Вот демоверсия видео

.. и вот ВСЕ код:

Если возможно, я бы хотел решить эту проблему, не прибегая к модификации самих скриптов AjaxToolkit.

<%@ Page Language="VB" AutoEventWireup="false" CodeFile="MyModalSimple.aspx.vb" Inherits="MyModalSimple" %>

<%@ Register Assembly="AjaxControlToolkit" Namespace="AjaxControlToolkit" TagPrefix="cc1" %>
<!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>
    <style type="text/css">
        .modalBackground
        {
            background-color: Gray;
            filter: alpha(opacity=70);
            opacity: 0.7;
        }
    </style>
    <link href="Default.css" rel="stylesheet" type="text/css" />

    <script type="text/javascript">

        function onOk() {
            //form1.submit();
        }
    </script>

    <script type="text/javascript">
        var clientid;
        function fnSetFocus(txtClientId) {
            clientid = txtClientId;
            setTimeout("fnFocus()", 1000);

        }

        function fnFocus() {
            //debugger;
            if (document.getElementById("pnlModal").style.display != "none")
                eval("document.getElementById('" + clientid + "').focus()");
        }

        function fnClickOK(sender, e) {
            __doPostBack(sender, e);
        }


    </script>

</head>
<body>
    <form id="form1" runat="server">
        <br />
        Clicking the button will bring up the modal dialog<br />
        <br />    
    <div>
        <asp:ScriptManager ID="ScriptManager1" runat="server">
        </asp:ScriptManager>
        <br />
        <asp:Button ID="Button1" runat="server" Text="Button" />
        <cc1:ModalPopupExtender ID="Button1_ModalPopupExtender" runat="server" TargetControlID="Button1"
            PopupDragHandleControlID="programmaticPopupDragHandle" PopupControlID="pnlModal"
            OkControlID="btnOK" CancelControlID="btnCancel" DropShadow="true" OnOkScript="onOk();"
            BackgroundCssClass="modalBackground">
        </cc1:ModalPopupExtender>
        <br />
        <asp:Panel ID="pnlModal" runat="server" Style="display: None" BackColor="#CCCCCC">
            <asp:Panel runat="Server" ID="programmaticPopupDragHandle" Style="cursor: move; background-color: #DDDDDD;
                border: solid 1px Gray; color: Black; text-align: center;">
                Caption
            </asp:Panel>
            <br />
            <table>
                <tr>
                    <td>
                        <asp:Label ID="lblFirst" runat="server" Text="First"></asp:Label>
                    </td>
                    <td>
                        <asp:TextBox ID="txtFirst" runat="server"></asp:TextBox>
                    </td>
                </tr>
                <tr>
                    <td>
                        <asp:Label ID="lblLast" runat="server" Text="Last"></asp:Label>
                    </td>
                    <td>
                        <asp:TextBox ID="txtLast" runat="server"></asp:TextBox>
                    </td>
                </tr>
                <tr>
                    <td>
                        &nbsp;
                    </td>
                    <td align="right">
                        <asp:Button ID="btnOK" runat="server" Text="OK" />
                        <asp:Button ID="btnCancel" runat="server" Text="Cancel" />
                    </td>
                </tr>
            </table>
        </asp:Panel>
        <asp:Label ID="lblMessage" runat="server"></asp:Label>
        <br />
        <br />
        </div>
    </form>
</body>
</html>

Partial Class MyModalSimple

    Inherits System.Web.UI.Page

    Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles Me.Load

        If Not Page.IsPostBack Then

            Button1.Attributes.Add("onclick", "fnSetFocus('" + txtFirst.ClientID + "');")

            btnOK.OnClientClick = String.Format("fnClickOK('{0}','{1}')", btnOK.UniqueID, "")

        End If

    End Sub

    Protected Sub btnOK_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles btnOK.Click
        lblMessage.Text = "Hi, " & txtFirst.Text & " " & txtLast.Text
    End Sub
End Class

1 Ответ

2 голосов
/ 14 января 2010

К сожалению, это известная ошибка в DragPanelExtender. Я бы порекомендовал сбросить модальный расширитель все вместе, если это вариант, и вам удобно с javascript.

Например, с jQuery / jQuery UI ваша страница будет выглядеть так:

<form id="form1" runat="server">
  <br />
  Clicking the button will bring up the modal dialog<br />
  <br />    
  <div>
    <br />
    <asp:Button ID="Button1" runat="server" Text="Button" />
    <br />
    <div id="myModal" Style="display: None" background="#CCCCCC" title="Caption/Dialog Title">
        <table>
            <tr>
                <td>
                    <asp:Label ID="lblFirst" runat="server" Text="First" />
                </td>
                <td>
                    <asp:TextBox ID="txtFirst" runat="server" />
                </td>
            </tr>
            <tr>
                <td>
                    <asp:Label ID="lblLast" runat="server" Text="Last" />
                </td>
                <td>
                    <asp:TextBox ID="txtLast" runat="server" />
                </td>
            </tr>
        </table>
    </div>
    <asp:Label ID="lblMessage" runat="server"></asp:Label>
    <br />
    <br />
    </div>
</form>
<script type="text/javascript">
  $(function() {
    $("#<%= Button1.ClientID %>").click() {
      $("#myModal").dialog({ buttons: { "Ok": function() { $(this).dialog("close"); } } });
    }
  });
</script>

Это совершенно другой способ программирования, но он дает гораздо более богатый пользовательский интерфейс для пользователя. Если вы хотите изучить jQuery и узнать, как он работает, это действительно естественный / гибкий синтаксис, который может добавить большую мощность / гибкость вашим веб-страницам. Теперь имейте в виду, что я предпочитаю jQuery, но есть много других доступных библиотек javascript . По крайней мере, вы должны просмотреть и посмотреть, что выглядит наиболее удобным, если вы только начинаете ... возможно, поскольку вы из VB-фона (я из C #), что стиль / синтаксис кодирования для других библиотек намного более привлекательным.

Теперь, если вы не хотите идти по этому пути и он слишком незнаком, насколько я могу судить, ваша единственная альтернатива - делать то, что вы не хотите ... скомпилируйте AJAX Control Toolkit самостоятельно. Если вы хотите пойти по этому пути, возьмите последний код из codeplex и измените следующий раздел Release\AjaxControlToolkit\Compat\DragDrop\DragDropScripts.js:

_drag: function(isInitialDrag) {
  var ev = window._event;
  var mousePosition = { x: ev.clientX, y: ev.clientY };

На это:

_drag: function(isInitialDrag) {
  if (!this._activeDragVisual) return;
  var ev = window._event;
  var mousePosition = { x: ev.clientX, y: ev.clientY };

Операция _onScrollerTick в некоторых браузерах выводит из строя и обнуляет функцию dragVisual. Здесь нужно отдать должное : Сообщение на форумах ASP.Net от freakyer привело меня по этому пути отладки, чтобы выяснить, где оно ломается ... но другого решения, как там, нет в некоторых браузерах это ошибка, которую нельзя исправить без изменения скрипта и перекомпиляции.

Я призываю вас рассмотреть путь к jQuery / other Framework, есть тонна поддержки сообщества и примеры, которые помогут вам начать работу. Этот вопрос того времени стоит прочитать, если вам вообще интересны варианты фреймворка.

...