很抱歉,这可能是不可能的,但是否有一种方法可以更改URL的哈希值而不在浏览器历史记录中留下条目并且不需要重新加载?或者进行等效操作?
具体来说,我正在开发基本的哈希导航,如下所示:
//hash nav -- works with js-tabs
var getHash = window.location.hash;
var hashPref = "tab-";
function useHash(newHash) {
//set js-tab according to hash
newHash = newHash.replace('#'+hashPref, '');
$("#tabs li a[href='"+ newHash +"']").click();
}
function setHash(newHash) {
//set hash according to js-tab
window.location.hash = hashPref + newHash;
//THIS IS WHERE I would like to REPLACE the location.hash
//without a history entry
}
// ... a lot of irrelavent tabs js and then....
//make tabs work
$("#tabs.js-tabs a").live("click", function() {
var showMe = $(this).attr("href");
$(showMe).show();
setHash(showMe);
return false;
});
//hash nav on ready .. if hash exists, execute
if ( getHash ){
useHash(getHash);
}
显然要使用jQuery。想法是在此特定情况下,1)使用户返回到每个选项卡更改可能会通过堆积不必要的引用有效地“破坏后退按钮”,2)如果用户刷新,则不保留他们当前所在的选项卡是一种恼人的问题。