JQuery вкладки в режиме AJAX помогают для сафари - PullRequest
1 голос
/ 07 мая 2011

Я создал вкладки jQuery в режиме ajax.

В одной из моих вкладок у меня есть кнопка возврата приложения, которая использует javascript: history.go(-1).

Все отлично работает в IE.Когда я нажимаю кнопку «Назад», я перехожу на начальную страницу в iFrame.Но когда я пробую ту же функциональность в Safari, кнопка переводит меня на мою домашнюю страницу.Я также понял, что кнопки браузера Safari делают то же самое, в то время как кнопки браузера IE работают отлично.

Я не могу понять причину, почему моя страница делает это.Любые идеи, чтобы это исправить?

<meta charset="utf-8">
    <script>
    $(function() {
        $( "#tabs" ).tabs({
            ajaxOptions: {
                error: function( xhr, status, index, anchor ) {
                    $( anchor.hash ).html(
                        "Couldn't load this tab. We'll try to fix this as soon as possible. " +
                        "If this wouldn't be a demo." );
                }
            }
        });
    });
    </script>

<div class="demo">

<div id="tabs">
    <ul>
        <li><a href="#tabs-1">Preloaded</a></li>
        <li><a href="ajax/content1.html">Tab 1</a></li>
        <li><a href="ajax/content2.html">Tab 2</a></li>
        <li><a href="ajax/content3-slow.php">Tab 3 (slow)</a></li>
        <li><a href="ajax/content4-broken.php">Tab 4 (broken)</a></li>
    </ul>
    <div id="tabs-1">
        <p>Proin elit arcu, rutrum commodo, vehicula tempus, commodo a, risus. Curabitur nec arcu. Donec sollicitudin mi sit amet mauris. Nam elementum quam ullamcorper ante. Etiam aliquet massa et lorem. Mauris dapibus lacus auctor risus. Aenean tempor ullamcorper leo. Vivamus sed magna quis ligula eleifend adipiscing. Duis orci. Aliquam sodales tortor vitae ipsum. Aliquam nulla. Duis aliquam molestie erat. Ut et mauris vel pede varius sollicitudin. Sed ut dolor nec orci tincidunt interdum. Phasellus ipsum. Nunc tristique tempus lectus.</p>
    </div>
</div>

</div><!-- End demo -->



<div class="demo-description">
<p>Fetch external content via Ajax for the tabs by setting an href value in the tab links.  While the Ajax request is waiting for a response, the tab label changes to say "Loading...", then returns to the normal label once loaded.</p>
<p>Tabs 3 and 4 demonstrate slow-loading and broken AJAX tabs, and how to handle serverside errors in those cases. Note: These two require a webserver to interpret PHP. They won't work from the filesystem.</p>
</div><!-- End demo-description -->

1 Ответ

1 голос
/ 07 мая 2011

попробуйте использовать javascript: self.history.go(-1)

проблема возникает из-за того, что Safari пытается вызвать window.history.go (-1), что приводит к вашей проблеме

Дальнейшее чтение: http://benalman.com/news/2009/12/webkit-bug-hash-history-iframe/

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