JavaScript中URL对象有哪些不为人知的强大功能或应用场景?

2026-04-05 17:028阅读0评论SEO教程
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计778个文字,预计阅读时间需要4分钟。

JavaScript中URL对象有哪些不为人知的强大功能或应用场景?

目录+前言+解析参数+修改URL+参数+总结+前言+URL+对象可能在页面端使用的比较少,一般来说,页面端对+URL+的操作,大部分都是解析+URL+参数,解析+URL+参数有比较多的库可以选择,例如+qs+,或++

目录
  • 前言
  • 解析参数
  • 修改 URL 参数
  • 总结

前言

URL 对象可能页端用的比较少一点,一般来说,页端对 URL 的操作,大部分都是解析 URL 参数,解析 URL 参数有比较多的库可以选,比如 qs,或者用浏览器原生的 URLSearchParams

JavaScript中URL对象有哪些不为人知的强大功能或应用场景?

// 假设当前的 url 为 'www.test.com?a=1&b=2' const b = new URLSearchParams(location.search); const aParam = b.get('a'); // 1 const bParam = b.get('b'); // 2 const entries = [...b]; // [['a', '1'], ['b', '2']] // 如果希望可以像 qs.parse 一样获取一个对象,可以这样做 const params = Object.fromEntries(entries); // {a: 'c', b: '2'}

解析参数

通过 URLSearchParams 解析参数,和 URL 这个对象看起来关联不是很大,但是可以看下 URL 对象实例化之后返回的对象

const a = new URL('www.test.com?a=1&b=2'); // hash: "" // host: "www.test.com" // hostname: "www.test.com" // href: "www.test.com/?a=1b=2" // origin: "www.test.com" // password: "" // pathname: "/" // port: "" // protocol: "www.test.com?a=1&b=2'); const entries = [...a.searchParmas]; const params = Object.fromEntries(entries); // 在浏览器控制台,一行 [...new URL(location.href).searchParams];

修改 URL 参数

淡出的解析参数,没必要动用 URL,用 URLSearchParams 这个对象完全是足够的,那么这个 URL 对象还可以做什么呢,其实可以想想 URLSearchParams 其实提供了 set append 这些写操作,同时,URL 对象返回的属性也是可以修改的,能不能通过修改 URL 里面的参数,实现修改一个 URL 或者说生成一个 URL ,毕竟很多时候,对 URL 的修改停留在字符串操作上,操作起来也很危险,很容易报错

const a = new URL('www.test.com?a=1&b=2'); a.searchParams.set('a', '18'); a.searchParams.set('b', '14'); a.searchParams.set('c', 'test'); let newURL = a.toString(); // www.test.com/?a=18&b=14&c=test a.hash = 'hasha'; newURL = a.toString(); // 'www.test.com/?a=18&b=14&c=test#hasha' a.host = 'www.init.com'; newURL = a.toString(); // www.init.com/?a=18&b=14&c=test#hasha

总结

URL 对象在操作 URL 里面还是比较方便的,简单封装一下可以少引很多包了,变通一下,可以反过来修改 URL 。这个对象在浏览器里面可以使用,但是可能面临着兼容性问题,如果是桌面端,放心用(IE 是啥),如果是移动端,可能需要配置polyfill。这个对象在 deno 中也能使用

到此这篇关于JavaScript URL对象的一些妙用的文章就介绍到这了,更多相关JavaScript URL对象妙用内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!

标签:一些妙用

本文共计778个文字,预计阅读时间需要4分钟。

JavaScript中URL对象有哪些不为人知的强大功能或应用场景?

目录+前言+解析参数+修改URL+参数+总结+前言+URL+对象可能在页面端使用的比较少,一般来说,页面端对+URL+的操作,大部分都是解析+URL+参数,解析+URL+参数有比较多的库可以选择,例如+qs+,或++

目录
  • 前言
  • 解析参数
  • 修改 URL 参数
  • 总结

前言

URL 对象可能页端用的比较少一点,一般来说,页端对 URL 的操作,大部分都是解析 URL 参数,解析 URL 参数有比较多的库可以选,比如 qs,或者用浏览器原生的 URLSearchParams

JavaScript中URL对象有哪些不为人知的强大功能或应用场景?

// 假设当前的 url 为 'www.test.com?a=1&b=2' const b = new URLSearchParams(location.search); const aParam = b.get('a'); // 1 const bParam = b.get('b'); // 2 const entries = [...b]; // [['a', '1'], ['b', '2']] // 如果希望可以像 qs.parse 一样获取一个对象,可以这样做 const params = Object.fromEntries(entries); // {a: 'c', b: '2'}

解析参数

通过 URLSearchParams 解析参数,和 URL 这个对象看起来关联不是很大,但是可以看下 URL 对象实例化之后返回的对象

const a = new URL('www.test.com?a=1&b=2'); // hash: "" // host: "www.test.com" // hostname: "www.test.com" // href: "www.test.com/?a=1b=2" // origin: "www.test.com" // password: "" // pathname: "/" // port: "" // protocol: "www.test.com?a=1&b=2'); const entries = [...a.searchParmas]; const params = Object.fromEntries(entries); // 在浏览器控制台,一行 [...new URL(location.href).searchParams];

修改 URL 参数

淡出的解析参数,没必要动用 URL,用 URLSearchParams 这个对象完全是足够的,那么这个 URL 对象还可以做什么呢,其实可以想想 URLSearchParams 其实提供了 set append 这些写操作,同时,URL 对象返回的属性也是可以修改的,能不能通过修改 URL 里面的参数,实现修改一个 URL 或者说生成一个 URL ,毕竟很多时候,对 URL 的修改停留在字符串操作上,操作起来也很危险,很容易报错

const a = new URL('www.test.com?a=1&b=2'); a.searchParams.set('a', '18'); a.searchParams.set('b', '14'); a.searchParams.set('c', 'test'); let newURL = a.toString(); // www.test.com/?a=18&b=14&c=test a.hash = 'hasha'; newURL = a.toString(); // 'www.test.com/?a=18&b=14&c=test#hasha' a.host = 'www.init.com'; newURL = a.toString(); // www.init.com/?a=18&b=14&c=test#hasha

总结

URL 对象在操作 URL 里面还是比较方便的,简单封装一下可以少引很多包了,变通一下,可以反过来修改 URL 。这个对象在浏览器里面可以使用,但是可能面临着兼容性问题,如果是桌面端,放心用(IE 是啥),如果是移动端,可能需要配置polyfill。这个对象在 deno 中也能使用

到此这篇关于JavaScript URL对象的一些妙用的文章就介绍到这了,更多相关JavaScript URL对象妙用内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!

标签:一些妙用