Адрес jQuery / Глубокая ссылка - PullRequest
1 голос
/ 17 августа 2011

У меня есть раздел с вкладками на веб-сайте, который я сейчас разрабатываю, и я хотел бы включить уникальные URL-адреса для каждой вкладки, а также поддержку истории.

Похоже, плагин jQuery Address - это способиди, но у меня возникли проблемы с его реализацией.Я могу назначить URL-адреса и изменить адресную строку.Кнопка «Назад» переходит по URL-адресам, но фактически не меняет вкладки.

Документация по адресу не очень хороша.Я предполагаю, что мне не хватает какого-либо прослушивателя событий, но я не уверен, как его инициализировать или к чему его применить.

Вот мой JS

$('.sm-tab').click(function() {
    $.address.value($('a', this).attr('href'));
    smReset();
    $('#sm-tabs').find('.active').each(function() {
        $(this).removeClass('active');
        $(this).addClass('inactive');
    });
    $(this).removeClass('inactive');
    $(this).addClass('active');
    var smClassArray = $(this).attr('class').split(" ");
    var smDivClass = smClassArray[1];
    $('#'+smDivClass).show();
});

Мой HTML выглядит примерно так

<div id="sm-tabs">
    <div class="sm-tab inactive twitter">
        <span class="twitter sprite-sm-twitter"><a href="?tab=twitter" class="hidetext">Twitter</a></span>
    </div>
    <div class="sm-tab inactive youtube">
        <span class="youtube sprite-sm-youtube"><a href="?tab=youtube" class="hidetext">YouTube</a></span>
    </div>
</div>

<div id="sm-widgets">
    <div id="twitter">
        Content
    </div>
    <div id="youtube">
        Content
    </div>
</div>

1 Ответ

1 голос
/ 18 августа 2011

Использование хешей для навигации по ajax откроет вам целую банку червей .

Попробуйте этот скрипт с глубокими связями , который использует API истории HTML5вместо этого.

...