?本篇文章给大家带来的内容是关于JavaScript解析URL的方法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
|
本篇文章给大家带来的内容是关于JavaScript解析URL的方法介绍(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 在 Web 开发中,有许多情况需要解析 URL,这篇主要学习如何使用 URL 对象实现这一点。 开始创建一个以下内容的 HTML 文件,并在浏览器中打开。 <html>
<head>
<title>JavaScript URL parsing</title>
</head>
<body>
<script>
// 激动人心的代码即将写在这里
</script>
</body>
</html>如果你想尝试本文中的任何内容,可以将其放在 <script> 标记中,保存,重新加载页面,看看会发生什么! 在本教程中,将使用 console.log 来打印所需要的内容,你可以打开开发都工具,来查看内容。 什么是 URL这应该是相当简单的,但让我们说清楚。 URL 是网页的地址,可以在浏览器中输入以获取该网页的唯一内容。 可以在地址栏中看到它:
URL 是统一资源定位符,对可以从互联网上得到的资源的位置和访问方法的一种简洁的表示,是互联网上标准资源的地址。互联网上的每个文件都有一个唯一的 URL,它包含的信息指出文件的位置以及浏览器应该怎么处理它。 此外,如果你不熟悉基本 URL 路径的工作方式,可以查看此文学习。 URL 不都长的一样的 获取当前URL获取当前页面的 URL 非常简单 - 我们可以使用 试着把这个添加到我们形如写的的脚本中: console.log(window.location); 查看浏览器的控制台:
不是你想要的?这是因为它不返回你在浏览器中看到的实际 URL 地址——它返回的是一个 URL 对象。使用这个 URL 对象,我们可以解析 URL 的不同部分,接下来就会讲到。 创建 URL 对象很快就会看到,可以使用 URL 对象来了解 URL 的不同部分。如果你想对任何 URL 执行此操作,而不仅仅是当前页面的 URL,该怎么办? 我们可以通过创建一个新的 URL 对象来实现。 以下是如何创建一个: var myURL = new URL('https://example.com');就这么简单! 可以打印 console.log(myURL);
出于本文的目的,将 myURL 设置为这个值: var myURL = new URL('https://example.com:4000/folder/page.html?x=y&a=b#section-2')将其复制并粘贴到 URL 对象的结构使用 URL 对象,可以非常轻松地获取 URL 的不同部分。 以下是你可以从 URL 对象获得的所有内容。 对于这些示例,我们将使用上面设置的 hrefURL 的 console.log(myURL.href); // Output: "https://example.com:4000/folder/page.html?x=y&a=b#section-2" 协议 (protocol)URL的协议是一开始的部分。这告诉浏览器如何访问该页面,例如通过 HTTP 或 HTTPS。 但是还有很多其他协议,比如 ftp(文件传输协议)和 ws(WebSocket)。通常,网站将使用 HTTP 或 HTTPS。 虽然如果你的计算机上打开了文件,你可能正在使用文件协议! URL对象的协议部分包括 console.log(myURL.protocol); // Output: "https:" 主机名(hostname)主机名是站点的域名。 如果你不熟悉域名,则它是在浏览器中看到的URL的主要部分 - 例如 console.log(myURL.hostname); // Output: "example.com" 端口(port)URL 的端口号位于域名后面,用冒号分隔(例如 端口号是服务器上用于获取数据的特定“通道” - 因此,如果我拥有 console.log(myURL.port); // Output: "4000" 主机(host)主机只是 console.log(myURL.host); // Output: "example.com:4000" 来源(origin)origin 由 URL 的协议,主机名和端口组成。 它基本上是整个 URL,直到端口号结束,如果没有端口号,到主机名结束。 console.log(myURL.origin); // Output: "https://example.com:4000" pathname(文件名)
console.log(myURL.pathname); // Output: "/folder/page.html" 锚点(hash)从 “#” 开始到最后,都是锚部分。可以将哈希值添加到 URL 以直接滚动到具有 ID 为该值的哈希值 的元素。 例如,如果你有一个 console.log(myURL.hash); // Output: "#section-2" 查询参数 (search)你还可以向 URL 添加查询参数。它们是键值对,意味着将特定的“变量”设置为特定值。 查询参数的形式为 ?key1=value1&key2=value2&key3=value3 请注意,如果 URL 也有 锚点(hash),则查询参数位于 锚点(hash)(也就是 ‘#’)之前,如我们的示例 URL 中所示: console.log(myURL.search); // Output: "?x=y&a=b" 但是,如果我们想要拆分它们并获取它们的值,那就有点复杂了。 使用 URLSearchParams 解析查询参数要解析查询参数,我们需要创建一个 URLSearchParams 对象,如下所示: var searchParams = new URLSearchParams(myURL.search); 然后可以通过调用 ?x=y&a=b 因此,如果我们调用 console.log(searchParams.get('x'));
// Output: "y"
console.log(searchParams.get('a'));
// Output: "b"扩展获取 URL 的中参数方法一:正则法 function getQueryString(name) {
var reg = new RegExp('(^|&)' + name + '=([^&]*)(&|$)', 'i');
var r = window.location.search.substr(1).match(reg);
if (r != null) {
return unescape(r[2]);
}
return null;
}
// 这样调用:
alert(GetQueryString("参数名1"));
alert(GetQueryString("参数名2"));
alert(GetQueryString("参数名3"));方法二:split拆分法 function GetRequest() {
var url = location.search; //获取url中"?"符后的字串
var theRequest = new Object();
if (url.indexOf("?") != -1) {
var str = url.substr(1);
strs = str.split("&");
for(var i = 0; i < strs.length; i ++) {
theRequest[strs[i].split("=")[0]] = unescape(strs[i].split("=")[1]);
}
}
return theRequest;
}
var Request = new Object();
Request = GetRequest();
// var 参数1,参数2,参数3,参数N;
// 参数1 = Request['参数1'];
// 参数2 = Request['参数2'];
// 参数3 = Request['参数3'];
// 参数N = Request['参数N'];修改 URL 的中某个参数值//替换指定传入参数的值,paramName为参数,replaceWith为新值
function replaceParamVal(paramName,replaceWith) {
var oUrl = this.location.href.toString();
var re=eval('/('+ paramName+'=)([^&]*)/gi');
var nUrl = oUrl.replace(re,paramName+'='+replaceWith);
this.location = nUrl;
window.location.href=nUrl
}以上就是JavaScript解析URL的方法介绍(代码示例)的详细内容,更多请关注模板之家(www.mb5.com.cn)其它相关文章! |
