Как мне остаться на той же вкладке на веб-странице после отправки формы с помощью Django? - PullRequest
0 голосов
/ 27 декабря 2018

Когда я обновляю страницу / отправляю форму для моего приложения django, она всегда переходит на первую вкладку, а не перенаправляет на вкладку, на которой в данный момент находился пользователь.Есть ли какое-то простое решение для этого, потому что я не нашел ответов онлайн

1 Ответ

0 голосов
/ 27 декабря 2018

Вы можете сохранить выбор вкладки в sessionStorage и использовать его при загрузке страницы.Если вы используете Bootstrap (и jQuery) и следуете их базовым рекомендациям , тогда код, подобный этому, должен выполнить свою работу:

// Save last active tab to sessionStorage
$('a[data-toggle="tab"]').on('shown.bs.tab', function () {
    try {
        sessionStorage.setItem('lastTab', $(this).attr('href'));
    } catch (error) {
        console.log(error);
    }
});

... и перейти к последней активной вкладке назагрузка страницы:

// Get last active tab from sesssionStorage and go there
var lastTab = sessionStorage.getItem('lastTab');
if (lastTab) {
    $('[href="' + lastTab + '"]').tab('show');
}

При использовании этого кода вы должны быть осторожны при использовании уникальных идентификаторов вкладок.

Включите это в шаблон Django, где у вас есть эти навигационные вкладки:

{% block extrahead %}
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/css/bootstrap.min.css" integrity="sha384-MCw98/SFnGE8fJT3GXwEOngsV7Zt27NXFoaoApmYm81iuXoPkFOJwJ8ERdknLPMO" crossorigin="anonymous">
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.3/umd/popper.min.js" integrity="sha384-ZMP7rVo3mIykV+2+9J3UJ46jBk0WLaUAdn689aCwoqbBJiSnjAK/l8WvCWPIPm49" crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.3/js/bootstrap.min.js" integrity="sha384-ChfqqxuZUCnJSK3+MXmPNIyE6ZbWh2IMqE241rYiqJxyMiZ6OW/JmZQ5stwEULTy" crossorigin="anonymous"></script>
<script>

    $(document).ready( function() {

        // Save last active tab to sessionStorage
        $('a[data-toggle="tab"]').on('shown.bs.tab', function () {
            try {
                sessionStorage.setItem('lastTab', $(this).attr('href'));
            } catch (error) {
                console.log(error);
            }
        });

        // Get last active tab from sesssionStorage and go there
        var lastTab = sessionStorage.getItem('lastTab');
        if (lastTab) {
            $('[href="' + lastTab + '"]').tab('show');
        }

    )};

</script>
{% endblock %}
{% block content %}
<ul class="nav nav-tabs" id="myTab" role="tablist">
  <li class="nav-item">
    <a class="nav-link active" id="home-tab" data-toggle="tab" href="#home" role="tab" aria-controls="home" aria-selected="true">Home</a>
  </li>
  <li class="nav-item">
    <a class="nav-link" id="profile-tab" data-toggle="tab" href="#profile" role="tab" aria-controls="profile" aria-selected="false">Profile</a>
  </li>
  <li class="nav-item">
    <a class="nav-link" id="contact-tab" data-toggle="tab" href="#contact" role="tab" aria-controls="contact" aria-selected="false">Contact</a>
  </li>
</ul>
<div class="tab-content" id="myTabContent">
  <div class="tab-pane fade show active" id="home" role="tabpanel" aria-labelledby="home-tab">...</div>
  <div class="tab-pane fade" id="profile" role="tabpanel" aria-labelledby="profile-tab">...</div>
  <div class="tab-pane fade" id="contact" role="tabpanel" aria-labelledby="contact-tab">...</div>
</div>
{% endblock %}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...