如果我使用:
alert(window.location.href);
我得到了包括查询字符串在内的所有信息。是否有一种方法只得到主url部分,例如:
http://mysite.com/somedir/somefile/
而不是
http://mysite.com/somedir/somefile/?foo=bar&loo=goo
如果我使用:
alert(window.location.href);
我得到了包括查询字符串在内的所有信息。是否有一种方法只得到主url部分,例如:
http://mysite.com/somedir/somefile/
而不是
http://mysite.com/somedir/somefile/?foo=bar&loo=goo
当前回答
每个答案都相当令人费解。在这里:
var url = window.location.href.split('?')[0];
即使一个?不存在,它仍然会返回第一个参数,这将是你的完整URL,减去查询字符串。
它也是协议无关的,这意味着你甚至可以用它来做ftp、itunes等事情。
其他回答
使用indexOf
var url = "http://mysite.com/somedir/somefile/?aa";
if (url.indexOf("?")>-1){
url = url.substr(0,url.indexOf("?"));
}
var url = "tp://mysite.com/somedir/somefile/?foo=bar&loo=goo"
url.substring(0,url.indexOf("?"));
使用URL()构造函数,然后提取并连接源和路径名。这将自动从url中剥离搜索(又名查询)参数,只留下方案、域、端口和路径名。
const url =新的url ('http://localhost:8080/index.html?search=foo&other=bar'); console.log (url。Origin + url.pathname);
需要注意的是,这种类型的转换通常被称为规范化,特别是在本例中是URI规范化。在您的环境中,可能已经存在具有更多选项的更健壮的库。
每个答案都相当令人费解。在这里:
var url = window.location.href.split('?')[0];
即使一个?不存在,它仍然会返回第一个参数,这将是你的完整URL,减去查询字符串。
它也是协议无关的,这意味着你甚至可以用它来做ftp、itunes等事情。
这是可能的,但你必须手动从location对象构建它:
location.protocol + '//' + location.host + location.pathname