我正在使用jquery $.ajax开发网站,以加载我在content/目录中拥有的不同页面的内容。我还使用hashtags来激活返回按钮、重新加载等功能。
但是,我有一个带有活动项目的主菜单,如果我在一个主菜单项目的页面深度导航,则该项目仍然处于活动状态。然后,我单击其中一个主菜单项目,例如“联系人”。因此,“联系人”菜单项变为活动状态。如果我点击浏览器的返回按钮,活动菜单项将不会更改。
那么,有没有办法记住活动主菜单项的状态?主菜单位于容器页面上。
谢谢!
但是,我有一个带有活动项目的主菜单,如果我在一个主菜单项目的页面深度导航,则该项目仍然处于活动状态。然后,我单击其中一个主菜单项目,例如“联系人”。因此,“联系人”菜单项变为活动状态。如果我点击浏览器的返回按钮,活动菜单项将不会更改。
那么,有没有办法记住活动主菜单项的状态?主菜单位于容器页面上。
谢谢!
$(function(){
$('.menu a')
.bind('click',function(e) {
e.preventDefault();
$('#content').html('Извините, страница не существует или находится в разработке!');
$('.menu a').each(function() {$(this).removeClass('activelink');});
location.hash=$(this).attr('href').match(/(([a-z]*)\W)*/)[2];
$(this).addClass('activelink');
return false;
});
$('#content').on('click','a',function(e) {
if (!($(this).hasClass('address') || $(this).hasClass('zoom'))){
e.preventDefault();
$('#content').html('Извините, страница не существует или находится в разработке!');
location.hash=$(this).attr('href').match(/(([a-z]*)\W)*/)[2];
return false;
}
else {
if ($(this).hasClass('address')) {
alert('Вы покидаете сайт The House Of Events. Возвращайтесь к нам еще!');
}
}
});
function hashChange(){
var page=location.hash.slice(1);
if (page!=""){
$.ajax({
type: "GET",
url: "content/" + page + ".html #sub-content",
success: function(data, status) {
$('#content').html(data);
},
error: function fail() {
$('#content').html('Error');
}
});
}
}
if ("onhashchange" in window){
$(window).on('hashchange',hashChange).trigger('hashchange');
} else {
var lastHash='';
setInterval(function(){
if (lastHash!=location.hash)
hashChange();
lastHash=location.hash;
},100);
}
});
history.pushState()
- d-_-b