Должен ли JQuery UI работать только с Google Chrome ??? (Как насчет IE и Firefox ??!) - PullRequest
1 голос
/ 11 марта 2010

Я использую «Jquery UI 1./Dan Wellman / Packt Publishing» для изучения JQuery UI. Я работаю над разделом «Виджет диалога».

После того, как я выполнил серию упражнений для создания виджета Dialog (используя Google Chrome), я попытался поработать с Internet Explorer и Firefox.

Результат был неутешительным.

  • Хром был безупречен
  • В Internet Explorer (1) заголовок диалогового виджета не отображался, (2) местоположение диалогового виджета было неправильным (с учетом позиции : ["center", "center"] ). Это было довольно смещено влево.
  • В Firefox местоположение было уважаемым. Однако был виден только внешний контейнер. содержимое отсутствовало, просто пустой контейнер.
  • Также с помощью Option Show: true и Hide: true работали только с Chrome.

Теперь мне интересно, должен ли пользовательский интерфейс JQuery использоваться только с Google Chrome. Я просто думаю, что я мог бы пропустить некоторые директивы, чтобы заставить его работать с основными браузерами (как утверждал автор в своей книге).

Вот код. Поскольку я использую ASP.NET MVC, некоторые коды, такие как элемент CSS, не отображаются. Но в остальном весь функционирующий код ниже.

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">

<p>
    The goal of this tutorial is to explain one method of creating 
    model classes for an ASP.NET MVC application. In this tutorial, 
    you learn how to build model classes and perform database access 
    by taking advantage of Microsoft LINQ to SQL. In this tutorial, 
    we build a basic Movie database application. We start by creating 
    the Movie database application in the fastest and easiest way possible. 
    We perform all of our data access directly from our controller actions.
</p>
<div style = "font-size:.7em" id = "myDialog" title = "This is the title">
    In this tutorial -- in order to illustrate how you can build model classes
    -- we build a simple Movie database application. 
    The first step is to create a new database. Right-click the
    App_Data folder in the Solution Explorer window and select the menu option
    Add, New Item. Select the SQL Server Database template, give it the name
    MoviesDB.mdf, and click the Add button (see Figure 1).
</div>
</asp:Content> 

<asp:Content ID="Content3" ContentPlaceHolderID="ScriptContent" 
runat="server">

<script src="../../Content/development-bundle/jquery-1.3.2.js"
type="text/javascript"></script>
<script src="../../Content/development-bundle/ui/ui.core.js"
type="text/javascript"></script>
<script src="../../Content/development-bundle/ui/ui.dialog.js"
type="text/javascript"></script>
<script src="../../Content/development-bundle/ui/ui.draggable.js" 
type="text/javascript"></script>
<script src="../../Content/development-bundle/ui/ui.resizable.js"
type="text/javascript"></script>
<script 
src="../../Content/development-bundle/external/bgiframe/jquery.bgiframe.js"
type="text/javascript"></script>

<script type = "text/javascript">
    $(function() {
        var execute = function() { }
        var cancel = function() { }
        var dialogOpts = {
            position: ["center", "center"],
            title: '<a href="/Home/About">A link title!<a>',
            modal: true,
            minWidth: 500,
            minHeight: 500,

            buttons: {
                "OK": execute,
                "Cancel": cancel
            },
            show:true,
            hide: true,
            bgiframe:true

        };
        $("#myDialog").dialog(dialogOpts);
    });
</script>

Спасибо за помощь.

EDIT

Я вчера сделал то же самое упражнение. С начала и до конца, каждый раз, когда я представлял поведение, я проверял свою работу во всех трех браузерах (IE, Firefox, Chrome).

  • Все работает, пока я не добавлю опцию Показать и скрыть. Тогда работает только Chrome.
  • Если я уберу «Показать и скрыть», все снова будет работать.
  • Если я оставлю только Показать и Скрыть, все отлично работает

Возможно, параметры Показать и Скрыть для диалогового виджета плохо сочетаются с другими параметрами.

Спасибо за помощь.

Ответы [ 5 ]

4 голосов
/ 11 марта 2010

Нет, интерфейс jQuery работает в любом из этих браузеров. Вероятно, либо шаги, которые вы выполняете, не работают так хорошо с используемой версией, или версия, которую вы используете, старая. Я использовал jQuery UI без проблем в обоих браузерах. Если вы мне не верите, откройте этот URL в вашем браузере:

http://jqueryui.com/demos/dialog/

В Firefox 3.6 он прекрасно загружается.

Я не эксперт по jQuery UI, но предоставление кода здесь может помочь.

2 голосов
/ 11 марта 2010

jQuery поддерживает все основные браузеры , однако есть известные проблемы с;

  • Firefox 1.0.x
  • Internet Explorer 1.0-5.x
  • Safari 1.0-2.0.1
  • Opera 1.0-8.x
  • Konqueror

Мы успешно реализовали виджет Dialog без особых проблем. У нас были некоторые проблемы с проверкой правильности версий библиотек. Я бы посоветовал вам создать собственный файл, используя jQuery UI download tool . Это поместит все необходимые файлы в один уменьшенный файл.

Если примеры Dialog не помогают, то для получения дополнительной помощи потребуется отправить код.

EDIT:

У меня есть якоря, созданные с классами dialogOpen и dialogClose, и я использую следующий код для использования созданного UI Dialog;

$(document).ready(function(){
            var dialogOpts = {
                autoOpen: false,
                modal: true,
                width: 840,
                height: 560
            };

            $(".dialogOpen").click(function(){
                $("#myDialog").dialog("open");
                return false;
            });

            $(".dialogClose").click(function(){
                $("#myDialog").dialog("close");
                return false;
            });

            $("#myDialog").css('display','block').dialog(dialogOpts);
            $(".ui-dialog-titlebar").hide();

        });

NB. Использование функции css при создании диалогового окна останавливает отображение содержимого на странице до создания диалога. Нам это нужно, потому что в нашем диалоге есть вспышка.

0 голосов
/ 11 марта 2010

Пользовательский интерфейс jQuery определенно не предназначен для работы только с Google Chrome.

Я успешно создал приложения с использованием пользовательского интерфейса jQuery, работающего на всех основных платформах браузеров.

Пользовательский интерфейс jQuery (и jQuery) содержат код для решения определенных проблем с браузером.

Конечно, могут быть проблемы в jQuery UI, которые отображаются в IE, например, этот , но они, конечно, не предназначены.

0 голосов
/ 11 марта 2010

JQuery должен быть кросс-браузерным. Любые ошибки с этим могут иметь причины - ошибка программиста - явная несовместимость

Есть некоторые явные несовместимости с IE5.5 и IE6 в jQuery. Они есть в комментариях jQuery, и хорошая совместимая с js IDE, например, netbeans, позволит нацеливаться и предупредить вас об этом.

У меня никогда не было проблем с позиционированием или содержимым диалогового виджета.

0 голосов
/ 11 марта 2010

Возможно, вы что-то упускаете. Это, безусловно, работает во всех основных браузерах.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...