支付后全局变量改变

2024-09-05 02:04
文章标签 支付 改变 全局变量

本文主要是介绍支付后全局变量改变,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

if (router.query.recharge_back_URI) {const _url = decodeURIComponent(router.query.recharge_back_URI as string);const url = new URL(_url, location.href);if (url.origin === location.origin) {router.replace(url.pathname);} else {location.href = url.href;}}

解释

这段代码的作用是检查 router.query 中是否包含 recharge_back_URI 参数,并根据这个参数的值执行相应的导航或重定向操作。

代码详解

if (router.query.recharge_back_URI) {const _url = decodeURIComponent(router.query.recharge_back_URI as string);const url = new URL(_url, location.href);if (url.origin === location.origin) {router.replace(url.pathname);} else {location.href = url.href;}
}
1. 检查 recharge_back_URI 参数
if (router.query.recharge_back_URI) {
  • 这行代码首先检查 router.query 对象中是否存在 recharge_back_URI 参数。
  • router.query 是 Next.js 路由对象,用于获取 URL 中的查询参数。如果存在 recharge_back_URI,则继续执行后续操作。
2. 解码 URL
const _url = decodeURIComponent(router.query.recharge_back_URI as string);
  • 这一行将 recharge_back_URI 参数的值进行 URL 解码。decodeURIComponent 用于将编码过的 URI 部分解码为正常的字符串形式。
3. 创建 URL 对象
const url = new URL(_url, location.href);
  • 这里使用 URL 构造函数来创建一个 URL 对象,传入 _url 作为相对或绝对 URL,location.href 作为基础 URL。
  • URL 构造函数可以处理相对 URL,并自动将其解析为完整的绝对 URL。
4. 判断目标 URL 与当前页面的 origin 是否一致
if (url.origin === location.origin) {router.replace(url.pathname);
} else {location.href = url.href;
}
  • url.originlocation.origin 是 URL 的协议、域名和端口的组合(例如 https://example.com)。
  • 这里的逻辑是:
    • 如果目标 URL 的 origin 与当前页面的 origin 相同,则使用 router.replace 方法将用户导航到目标 URL 的路径部分 (url.pathname)。router.replace 会替换浏览器历史记录中的当前条目,而不是创建一个新的条目。
    • 如果目标 URL 的 origin 不同,则直接通过 location.href 将页面重定向到目标 URL。这个操作会导致浏览器加载新的页面,可能会离开当前站点。

总结

这段代码的功能是在处理用户支付完成后的回调场景下,根据 recharge_back_URI 指定的路径或 URL,决定是本地导航到同源路径,还是重定向到其他域名的页面。它确保了在本地路径跳转时不会改变浏览器历史记录,而在跨域跳转时直接重定向用户。

这篇关于支付后全局变量改变的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137658

相关文章

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

C++中全局变量和局部变量的区别

《C++中全局变量和局部变量的区别》本文主要介绍了C++中全局变量和局部变量的区别,全局变量和局部变量在作用域和生命周期上有显著的区别,下面就来介绍一下,感兴趣的可以了解一下... 目录一、全局变量定义生命周期存储位置代码示例输出二、局部变量定义生命周期存储位置代码示例输出三、全局变量和局部变量的区别作用域

在Linux中改变echo输出颜色的实现方法

《在Linux中改变echo输出颜色的实现方法》在Linux系统的命令行环境下,为了使输出信息更加清晰、突出,便于用户快速识别和区分不同类型的信息,常常需要改变echo命令的输出颜色,所以本文给大家介... 目python录在linux中改变echo输出颜色的方法技术背景实现步骤使用ANSI转义码使用tpu

Python中局部变量和全局变量举例详解

《Python中局部变量和全局变量举例详解》:本文主要介绍如何通过一个简单的Python代码示例来解释命名空间和作用域的概念,它详细说明了内置名称、全局名称、局部名称以及它们之间的查找顺序,文中通... 目录引入例子拆解源码运行结果如下图代码解析 python3命名空间和作用域命名空间命名空间查找顺序命名空

SpringBoot实现微信小程序支付功能

《SpringBoot实现微信小程序支付功能》小程序支付功能已成为众多应用的核心需求之一,本文主要介绍了SpringBoot实现微信小程序支付功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录一、引言二、准备工作(一)微信支付商户平台配置(二)Spring Boot项目搭建(三)配置文件

SpringBoot基于沙箱环境实现支付宝支付教程

《SpringBoot基于沙箱环境实现支付宝支付教程》本文介绍了如何使用支付宝沙箱环境进行开发测试,包括沙箱环境的介绍、准备步骤、在SpringBoot项目中结合支付宝沙箱进行支付接口的实现与测试... 目录一、支付宝沙箱环境介绍二、沙箱环境准备2.1 注册入驻支付宝开放平台2.2 配置沙箱环境2.3 沙箱

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

react笔记 8-18 事件 方法 定义方法 获取/改变数据 传值

1、定义方法并绑定 class News extends React.Component {constructor(props) {super(props)this.state = {msg:'home组件'}}run(){alert("我是一个run") //方法写在类中}render() {return (<div><h2>{this.state.msg}</h2><button onCli

在实现回显功能模块的时候,把ID设置成全局变量了

在hsapprove.jsp中: <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%><script type="text/javascript">function edittodayhs(hsid){//alert(hsid);//