这篇文章主要讲解了“如何使用JavaScript中URL对象”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何使用JavaScript中URL对象”吧!
前言
解析参数
修改 URL 参数
URL 对象可能页端用的比较少一点,一般来说,页端对 URL 的操作,大部分都是解析 URL 参数,解析 URL 参数有比较多的库可以选,比如 qs,或者用浏览器原生的 URLSearchParams
// 假设当前的 url 为 'https://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('https://www.test.com?a=1&b=2'); // hash: "" // host: "www.test.com" // hostname: "www.test.com" // href: "https://www.test.com/?a=1b=2" // origin: "https://www.test.com" // password: "" // pathname: "/" // port: "" // protocol: "https:" // search: "?a=1&b=2" // searchParams: URLSearchParams {} // username: "" // [[Prototype]]: URL
从返回的对象可以看到,URL 实例化之后,返回的属性 searchParams 实际上就是一个实例化的 URLSearchParams 对象。所以获取参数的操作,其实也有一个方法是通过 URL 对象去获取,例如上面的操作可以改一下
const a = new URL('https://www.test.com?a=1&b=2'); const entries = [...a.searchParmas]; const params = Object.fromEntries(entries); // 在浏览器控制台,一行 [...new URL(location.href).searchParams];
淡出的解析参数,没必要动用 URL,用 URLSearchParams 这个对象完全是足够的,那么这个 URL 对象还可以做什么呢,其实可以想想 URLSearchParams 其实提供了 set append 这些写操作,同时,URL 对象返回的属性也是可以修改的,能不能通过修改 URL 里面的参数,实现修改一个 URL 或者说生成一个 URL ,毕竟很多时候,对 URL 的修改停留在字符串操作上,操作起来也很危险,很容易报错
const a = new URL('https://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(); // https://www.test.com/?a=18&b=14&c=test a.hash = 'hasha'; newURL = a.toString(); // 'https://www.test.com/?a=18&b=14&c=test#hasha' a.host = 'www.init.com'; newURL = a.toString(); // https://www.init.com/?a=18&b=14&c=test#hasha
感谢各位的阅读,以上就是“如何使用JavaScript中URL对象”的内容了,经过本文的学习后,相信大家对如何使用JavaScript中URL对象这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。