我的编程空间,编程开发者的网络收藏夹
学习永远不晚

关于JavaScript中URL对象的一些妙用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

关于JavaScript中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 参数

淡出的解析参数,没必要动用 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

总结

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

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

关于JavaScript中URL对象的一些妙用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

当关系的一侧已存在于数据库中时,使用 SQLModel 插入多对多关系对象

问题内容我正在尝试使用 sqlmodel 在数据库中插入记录,其中数据如下所示。一个 house 对象,它有颜色和许多位置。地点也将与许多房屋相关联。输入为:[{"color": "red","locations": [{"type
当关系的一侧已存在于数据库中时,使用 SQLModel 插入多对多关系对象
2024-02-06

使用js获取url中的参数并返回一个对象方式

这篇文章主要介绍了使用js获取url中的参数并返回一个对象方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-17

关于javascript中伪数组和真数组的一些小秘密

在javascript中,伪数组又称类数组,是一个类似数组的对象,是一种按照索引存储数据且具有length属性的对象,下面这篇文章主要给大家介绍了关于javascript中伪数组和真数组的一些小秘密,需要的朋友可以参考下
2022-11-13

对于《关于使用Delphi XE10 进行android开发的一些总结》的补充

看了一篇《关于使用Delphi XE10 进行android开发的一些总结》有些想说的。 以下内容有复制原文,正常字体显示的是原文,黑体是我想说的。 我并不想讨论什么样的开发语言更优秀,只希望能以我自己的体会、总结的使用情况,说出我的感受
2022-06-06

Android中关于CoordinatorLayout的一些实用布局技巧

介绍 CoordinatorLayout是一个“加强版”的 FrameLayout,它主要有两个用途:(1) 用作应用的顶层布局管理器(2) 通过为子View指定 behavior 实现自定义的交互行为。在我们做 Material Desi
2022-06-06

web前端:关于css中@media的一些基本使用

编程学习网:层叠样式表(英文全称:CascadingStyleSheets)是一种用来表现html(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的计算机语言。css不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。
web前端:关于css中@media的一些基本使用
2024-04-23

JavaScript中访问节点对象的方法有哪些如何使用

js访问节点对象的方法有很多,比如getElementById在本文将举例为大家介绍下
2022-11-15

关于Node.js中Buffer的一些你可能不知道的用法

前言 在大多数介绍 Buffer 的文章中,主要是围绕数据拼接和内存分配这两方面的。比如我们使用fs模块来读取文件内容的时候,返回的就是一个 Buffer:fs.readFile('filename', function (err, buf
2022-06-04

使用 Tkinter Notebooks 时,如何将一个选项卡中的 StringVar 用于另一个选项卡对象,同时允许 f 字符串使用和实时更新

问题内容我正在创建一个小项目来帮助创建 bg3 mods。我的最终目标是拥有多个选项卡,我可以在其中输入数据,并在我保存时导出文件。我能够毫无问题地执行保存和选项卡创建。我想要发生的是在 configtab 中输入 mod 将创建的自定
使用 Tkinter Notebooks 时,如何将一个选项卡中的 StringVar 用于另一个选项卡对象,同时允许 f 字符串使用和实时更新
2024-02-09

编程热搜

目录