Кнопка браузера назад / вперед для перемещения между вкладками

14

Я получаю много жалоб от пользователей, что, когда они используют мои вкладки на основе jQuery, они раздражают, что когда они возвращаются в свой браузер, они переходят не на предыдущую вкладку, а на предыдущую страницу. , Я добавил следующие предыдущие / следующие кнопки, но недостаточно. Как я могу перенастроить свои кнопки так, чтобы пользователи переходили на предыдущую вкладку, а не на предыдущую страницу, когда они нажимали стрелку браузера назад. Вы можете проверить это здесь .

$('#quicktabs-registration_steps').append('<div class="prevnext"><a class="tablink-prev btn" href="#">Prev</a><a class="tablink-next btn btn-lg btn-primary" href="#">Continue</a></div>');
$('.tablink-prev').click(function () {
    var index = $('.quicktabs-tabs li.active').index();
    $('.quicktabs-tabs li').eq(index).removeClass('active');
    if (index == 0) {
        index = 1;
    }
    $('.quicktabs-tabs li').eq(index - 1).addClass('active');
    $('.quicktabs-tabs li').eq(index - 1).find('a').click();
    return false;
});
$('.tablink-next').click(function () {
    var length = $('.quicktabs-tabs').first().children().size();;
    var index = $('.quicktabs-tabs li.active').index();
    $('.quicktabs-tabs li').eq(index).removeClass('active');
    //                if (parseInt(index) == parseInt(length) - 1 ) {
    //                    index = index - 1;
    //                }
    if (parseInt(index) == parseInt(length) - 1) {
        window.location.href = '/home'; //redirect to home
        //index = index - 1;
    }
    $('.quicktabs-tabs li').eq(index + 1).addClass('active');
    $('.quicktabs-tabs li').eq(index + 1).find('a').click();
    return false;
});
Efe
источник
При необходимости добавьте # tab1 и # tab2 за URL-адресом
Джерард,
Привет @Gerard, не следуя, вы можете показать пример.
Efe
Вы должны знать, что предотвращение перехода любого браузера назад или вперед может стать устаревшим из-за того, что при наличии вредоносных сценариев они могут и будут контролировать ваш браузер, что пытаются предотвратить крупные разработчики браузера. любой ценой.
BRO_THOM
Взгляните на плагин jqueryUI Tabs: jqueryui.com/tabs . Также их документация дает подробности о клавиатурной навигации тоже. api.jqueryui.com/tabs . Посмотри.
Прасад Варгад
@ Ты это решил?
Аабир Хуссейн

Ответы:

13

Вы можете использовать историю.

Выдвинуть историческое состояние при открытии новой вкладки

history.pushState({page: 1}, "title 1", "?page=1")

Ссылка: https://developer.mozilla.org/en-US/docs/Web/API/History_API

isidat
источник
Я не проверял ваш код, но думаю, что он будет правильно перемещаться и не сможет поддерживать активную вкладку (выбранная вкладка)?
Aabir Hussain
7

Без вашего полного кода я не могу дать вам сделанный на заказ пример, но вы можете просто добавить якорные теги к каждой вкладке, содержащей div.

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

<div id="Tab1">
  <h2><a href="#Tab1">Tab 1</a></h2>
  <p>This tab content</p>
</div>

<div id="Tab2">
  <h2><a href="#Tab2">Tab 2</a></h2>
  <p>This tab content</p>
</div>

<div id="Tab3">
  <h2><a href="#Tab3">Tab 3</a></h2>
  <p>This tab content</p>
</div>

<div id="Tab4">
  <h2><a href="#Tab4">Tab 4</a></h2>
  <p>This tab content</p>
</div>

Обновленный URL будет выглядеть так каждый раз, когда вы нажимаете вкладку:

https://example.com#Tab1

https://example.com#Tab2

https://example.com#Tab3

https://example.com#Tab4

DreamTeK
источник
2

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

Таким образом, у вас есть два способа сделать это:

1-й: попробуйте загрузить каждый шаг на отдельной странице, обновив браузер, чтобы страница сохранялась в истории браузера и, нажав кнопку назад, вы можете увидеть предыдущий шаг

2-й: у вас должна быть кнопка «предыдущий», чтобы увидеть предыдущий шаг точно так же, как ваша кнопка следующего шага

Саид Джамали
источник
2
На самом деле есть способ, и вот почему история API в браузерах, это позволяет разработчикам истории просмотра обновлений в вашем приложении, и его обычно используют в SPA developer.mozilla.org/en-US/docs/Web/API/History_API
ROOT
2

Я использовал загрузочные вкладки с навигацией по вкладкам браузера ниже, полный пример

<div class="tabs-Nav border-top-0">
    <ul class="nav" role="tablist">
        <li>
            <a
            id="friends"
            data-pagination-id="friends"
            class="active"
            data-toggle="tab"
            href="#friendsTab"
            role="tab"
            aria-controls="friends"
            aria-selected="true">
                Friends
            </a>
        </li>
        <li>
            <a id="followers" data-pagination-id="followers" class="" data-toggle="tab" href="#followersTab" role="tab" aria-controls="followers" aria-selected="false">
                Followers
            </a>
        </li>
        <li>
            <a id="followings" data-pagination-id="followings" class="" data-toggle="tab" href="#followingTab" role="tab" aria-controls="followings" aria-selected="false">
                Following
            </a>
        </li>
        <li>
            <a id="invites" data-pagination-id="invites" class="" data-toggle="tab" href="#invitesTab" role="tab" aria-controls="invites" aria-selected="false">
                Invites
            </a>
        </li>
    </ul>
</div>


/**
* add // id="friends" data-pagination-id="friends"
* in your html tabs the demo html is also added.
**/
$(document).ready(function () {
    const param = 'tabID';
    $("[data-pagination-id]").click(function () {

        const pageParam = $(this).attr('data-pagination-param') || param;

        //add tabId to the params
        addParam(pageParam, $(this).attr('data-pagination-id'), true);
    });

    const preTab = getParamVal(param);

    if (param) {
        $('[data-pagination-id="'+ preTab +'"]').click();
    }
});


 /**
 * add params to the url if preParams is false then all previous
 * params will be removed.
 **/
addParam = (pageParam, paramValue, preParams) => {
    //get current url without params
    var mainUrl = window.location.href.split('?')[0];

    //get params without url
    var paramString = location.search.substring(1);

    if (preParams && paramString) { //when params found

        //change param string to json object
        var paramsObj = JSON.parse('{"' + decodeURI(paramString).replace(/"/g, '\\"').replace(/&/g, '","').replace(/=/g, '":"') + '"}');
    } else {
        //when current params are empty then create an empty object.
        var paramsObj = {};
    }

    //only for ads tabs
    if (pageParam) {
        //add tabId to the params
        paramsObj[pageParam] = paramValue;

        //push params without refreshing the page.
        history.pushState(false, false, mainUrl + '?' + $.param(paramsObj).replace(new RegExp('%2B', 'gi'), '+'));
    }
};

 /**
 * Get value of a params from url if not exists then return null
 **/
getParamVal = (pageParam) => {
    const mainUrl = window.location.href.split('?')[0];
    const paramString = location.search.substring(1);
    const paramsObj = JSON.parse('{"' + decodeURI(paramString).replace(/"/g, '\\"').replace(/&/g, '","').replace(/=/g, '":"') + '"}');

    return paramsObj[pageParam];
};

Вы можете проверить живой рабочий пример моего кода

1> Перейти на https://www.notesgen.com (использовать рабочий стол)

2> Создайте свой аккаунт как студент

3> Перейти к моей учетной записи / Мои загрузки

4> Нажмите на мои соединения

Аабир Хуссейн
источник
1

Изменение хеша похоже на нажатие состояния, history.pushStateкоторое вызываетpopstate событие. Попадание назад и вперед в браузере вызовет появление и выдвижение этих состояний, так что вам не понадобится никакой другой пользовательский обработчик.

PS: Вы можете добавить стиль CSS :targetиз вашего activeкласса. В window.addEventListener('popstate'здесь только журналы , чтобы показать вам событие , кромеevent.state всегда будет нулевым в этом случае.

Запустите фрагмент кода, попробуйте перемещаться по вкладкам, а затем используйте кнопки браузера назад и вперед.

<style type="text/css">
    div { display: none }
   :target { display: block }
</style>


  <h2><a href="#Tab1">Tab 1</a> | <a href="#Tab2">Tab 2</a> | <a href="#Tab3">Tab 3</a> | <a href="#Tab4">Tab 4</a></h2>


<div id="Tab1">
  <p>This tab 1 content</p>
</div>

<div id="Tab2">
  <p>This tab 2 content</p>
</div>

<div id="Tab3">
  <p>This tab 3 content</p>
</div>

<div id="Tab4">
  <p>This tab 4 content</p>
</div>

<script>
  (() => {
history.pushState(null, '', '#Tab1');
window.addEventListener('popstate', event => {
 console.log(window.location.hash);
});
})()
</script>

международный математический союз
источник
0

Первое, что вам нужно, запретите ссылке отправлять URL в истории с помощью $ event.preventDefualt () в событии клика и настройте историю с помощью history.pushState (data, title, url) .

В js у нас есть событие, которое помогает нам контролировать события «назад» и «вперед» пользователем. Это событие называется «popstate». Вы можете использовать его с помощью window.addEventListener (popstate, callback) . в функции обратного вызова вы можете активировать и деактивировать вкладку (добавить и удалить класс) и извлечь URL.

Я показываю это с примером кода. для лучшего понимания лучше попробовать его на сервере или на локальном сервере, потому что изменение URL здесь ограничено:

$('nav ul a').on('click', function($e) {
        function appendContent(hash) {
            $('#content').text(`Content of  item ${hash} `);
        }
        $e.preventDefault(); // when click the link stay in page
        let _this = this; // get the link tag
        let hash = _this.hash.replace(/\#/, '');
        
        appendContent(hash);
        $('li').removeAttr('class');
        $('a').removeAttr('class');
        $(`a[href*=${hash}]`).addClass('text-white').addClass('border-0').parent().addClass('bg-primary').addClass('last-style');
     
           history.pushState('', _this.text, hash); // add the link in history
  
        window.addEventListener('popstate', function ($e) {
             let hashAgain = location.hash.replace(/\#/, ''); // you extract the hash
            appendContent(hashAgain); // set the content of the back or forward link
          $('li').removeAttr('class');
        $('a').removeAttr('class');
        $(`a[href*=${hash}]`).addClass('text-white').addClass('border-0').parent().addClass('bg-primary').addClass('last-style'); // update the status of tab 
          
            
        });
    });
ul li {
  display: inline-block;
  margin: 1em; 
}

li a,
.last-style {
  border: 1px solid;
  padding: 0.5em 1em;
}
<!doctype html>
<html lang="en">
	<head>
		<meta charset="utf-8" >
		<meta name="viewport" content="width=device-width, initial-scale=1">
		<title>Learning Java Script In Deep</title>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/css/bootstrap.min.css">
		<script type="text/javascript" src="js/angular/angular.min.js"></script>
	</head>
	<body>
	
		<header class="text-center text-black-50">
			<h1>Learning JS in Deep</h1>
			<nav id="">
				<ul id="">
					<li><a href="#home" class="home">Home</a></li>
					<li><a href="#item1">Item 1</a></li>
					<li><a href="#item2">Item 2</a></li>
					<li><a href="#item3">Item 3</a></li>
					<li><a href="#item4">Item 4</a></li>
				</ul>
			</nav>
		</header>

        <div class="container m-auto text-center" id="content">
            <p>Load <em class="text-danger">Content</em> in Here</p>
        </div>

        <script
  src="https://code.jquery.com/jquery-3.4.1.js"
  integrity="sha256-WpOohJOqMqqyKL9FccASB9O0KwACQJpFTUBLTYOVvVU="
  crossorigin="anonymous"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.16.0/umd/popper.min.js"></script>
    <!-- Latest compiled JavaScript -->
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.4.1/js/bootstrap.min.js"></script>
        
		
	</body>	
</html>

Хасан Асади
источник