前端URL拼接路径参数

一、应用场景

我们有时候会遇到浏览器URL拼接参数的场景,例如页面跳转时,带上一个特定的标识:https://www.baidu.com?from=csdn

二、具体实现

1.字符串拼接

我们首先能想到用字符串拼接的方式实现

const baseUrl = 'https://www.baidu.com'
const url = baseUrl  + '?from=csdn'

但是如果要跳转的url并不是固定的时候,比如:

const baseUrl = 'https://www.baidu.com/s?wd=time'
const url = baseUrl  + '&from=csdn'

所以我们在拼接参数的时候要先行判断,原url是否已经包含参数,如果不包含要以?开头,反之要以&开头

2.URL对象实现

我们可以用浏览器给我们提供的URL API(不兼容IE)

  const url = new URL("https://www.baidu.com/s?wd=time");
  console.log(url)

在这里插入图片描述
我们就得到了一个解析好的URL对象
如果我们想增加参数,直接在searchParams对象中增加就行

  const url = new URL("https://www.baidu.com/s?wd=time");
  url.searchParams.append('from', 'csdn');
  console.log(url)

在这里插入图片描述
这样我们的参数就添加好了,我们只需要调用 url.toString()方法就能得到完整的路径了

四、完整代码

  const url = new URL("https://www.baidu.com/s?wd=time");
  url.searchParams.append('from', 'csdn');
  console.log(url)
  console.log(url.toString())

在这里插入图片描述

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据引用\[1\]中的代码,可以使用`request.args.get`方法来获取URL路径中`?`后面参数的值。例如,如果URL路径为`http://example.com?password=nio123456!A`,则可以使用`request.args.get("password", True)`来获取参数`password`的值,即`nio123456!A`。 另外,根据引用\[2\]中的代码,可以使用`getParams`函数将对象转换为URL参数。该函数会将对象的键值对使用`&`符号拼接成字符串。例如,如果有一个对象`params`,其中包含键值对`{a:1, b:2}`,则可以使用`getParams(params)`来将其转换为字符串`a=1&b=2`。 最后,根据引用\[3\]中的代码,可以使用`split`方法和正则表达式来处理URL路径中`?`后面的参数。具体的处理代码可以参考引用中的示例。 综上所述,根据不同的需求和具体的代码实现,可以使用不同的方法来获取URL路径中`?`后面的参数。 #### 引用[.reference_title] - *1* [Flask系列之:获取url路径中?后面参数的值](https://blog.csdn.net/zhengzaifeidelushang/article/details/123566981)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [js将url的?后面的参数转成对象](https://blog.csdn.net/Red_sevenWord/article/details/122999097)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down28v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值