js封装函数处理 url 地址拼接参数。

本文介绍了如何在JavaScript开发中封装函数以方便地向URL添加参数,特别是在处理可能已存在的URL参数时。使用了`URLSearchParams`构造函数和相关方法,如`toString()`,并提供了`buildUrlWithParams`和`buildUrlWithToken`示例,以及MDN文档链接以供进一步学习。
摘要由CSDN通过智能技术生成

在开发工作中,我们经常会又这样的情景——得到一个url地址,需要往url后面拼接上一些params参数。

我们每次都写拼接字符串,非常的麻烦,而且这个url地址可能是后端返回,或者是存储过的变量,我们不知道url上是否已经有了参数,所以要考虑  '?' 和 '&'。

所以我们就封装一下函数,我们只需要传 url  和想拼接的  params 就能得到 拼接好的 url地址。

个人实力有限,不足之处,敬请指正~

ok,开干。

// 给url后面拼接参数
export function buildUrlWithParams(url = "", params = {}) {
  //若参数对象不存在或为空,直接返回url
  if (!params || Object.keys(params).length === 0) {
    return url
  }
  //将参数转化为字符串 eg: {userId: 123,token:'abc'} => 'userId=123&token=abc'
  return url + (url.includes("?") ? "&" : "?") + new URLSearchParams(params).toString()
}


// 给url后面拼接userId和token参数
export function buildUrlWithToken(url = "") {
  return buildUrlWithParams(url, { userId: user.getUserId(), token: user.getUserToken() })
}



user.getUserId() 和 user.getUserToken() 是我们项目里面自己封装的获取 userId 和 token 的,仅展示。 大家可以自己处理。

函数里面使用了 new URLSearchParams ()  .这是一个构造函数,定义了一些实用的方法来处理 URL 的查询字符串。 返回的实例上有一些方法可以操作url 参数。

new URLSearchParams(params).toString()  返回搜索参数组成的字符串,可直接使用在URL上。

具体的用法 和 其它的实例方法 mdn上有介绍

MDN文档链接:https://developer.mozilla.org/zh-CN/docs/Web/API/URLSearchParams/URLSearchParams

  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值