如何使用jQuery从URL获取锚点?

时间:2010-08-24 01:25:12

标签: javascript jquery url anchor

我的网址如下:

www.example.com/task1/1.3.html#a_1

如何使用jQuery获取a_1锚点值并将其存储为变量?

6 个答案:

答案 0 :(得分:463)

对于当前窗口,您可以使用:

var hash = window.location.hash.substr(1);

要获取主窗口的哈希值,请使用:

var hash = window.top.location.hash.substr(1);

如果你有一个带有URL / hash的字符串,最简单的方法是:

var url = 'https://www.stackoverflow.com/questions/123/abc#10076097';
var hash = url.split('#').pop();

如果你正在使用jQuery,请使用:

var hash = $(location).attr('hash');

答案 1 :(得分:198)

您可以使用.indexOf().substring(),如下所示:

var url = "www.aaa.com/task1/1.3.html#a_1";
var hash = url.substring(url.indexOf("#")+1);

You can give it a try here,如果其中可能没有#,请执行if(url.indexOf("#") != -1)检查,如下所示:

var url = "www.aaa.com/task1/1.3.html#a_1", idx = url.indexOf("#")
var hash = idx != -1 ? url.substring(idx+1) : "";

如果这是当前页面网址,您可以使用window.location.hash获取该网址,并根据需要替换#

答案 2 :(得分:62)

使用

window.location.hash

检索超出并包括#

的所有内容

答案 3 :(得分:35)

jQuery样式:

$(location).attr('hash');

答案 4 :(得分:9)

您可以使用以下"技巧"解析任何有效的URL。它利用了anchor element的特殊href相关属性hash

使用jQuery

function getHashFromUrl(url){
    return $("<a />").attr("href", url)[0].hash.replace(/^#/, "");
}
getHashFromUrl("www.example.com/task1/1.3.html#a_1"); // a_1

使用普通JS

function getHashFromUrl(url){
    var a = document.createElement("a");
    a.href = url;
    return a.hash.replace(/^#/, "");
};
getHashFromUrl("www.example.com/task1/1.3.html#a_1"); // a_1

答案 5 :(得分:3)

如果你只有一个普通的url字符串(因此没有hash属性),你也可以使用正则表达式:

var url = "www.example.com/task1/1.3.html#a_1"  
var anchor = url.match(/#(.*)/)[1]