javascritp如何判断是从刷新(重新加载)、正常打开(或链接打开)、还是从浏览器回退进入页面的?同时介绍iframe子页面切换时控制是否在浏览器中增加历史回退记录

本文主要是介绍javascritp如何判断是从刷新(重新加载)、正常打开(或链接打开)、还是从浏览器回退进入页面的?同时介绍iframe子页面切换时控制是否在浏览器中增加历史回退记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

重点先下另外一个知识点

在我们的Web站点采用主体页面的iframe导航各个子页面(浏览器地址在不pushState或replaceState时将保持不变)的情况,当iframe中通过变更src属性值变更打开的子页面时,浏览器会自动添加一条可回退的历史记录,后续能够在浏览器中点击后退按钮或在主体页面history.go(-1)进行回退和前进页面。这种情况有可能是我们希望的,也有可能是我们不希望出现的(比如用来模拟tab页的情况)。

那如何控制iframe子页面切换时不增加历史记录呢?

1. 最简单的方式:切换src时重新渲染iframe(https://www.jianshu.com/p/90c228f6bcb0):

vue中,直接给iframe加一个key属性:       

 <iframe :src="srcUrl" :key="src" />

由于vue中的key更改时会重新渲染这个组件,因此这个方法是可行的。我们直接将src值赋值给key就可以实现切换src时重新渲染iframe了。

2. 不通过iframe的src属性值切换子页面,而是采用“iframe.contentWindow.location.replace” (https://blog.csdn.net/WMW_wmw/article/details/127344807):

watch: {'srcUrl'(newValue, oldValue) {setTimeout(() => {let iframe = this.$refs.iframeif (newValue !== undefined && newValue !== null && iframe !== undefined) {iframe.contentWindow.location.replace(newValue)}}, 50)}
},

以下代码则是向浏览器的回退历史栈增加一个记录,但浏览器不会在调用 pushState() 之后尝试加载该方法指定的地址(注意:新的URL可以是绝对路径或相对路径,但必须与当前 URL 同源,如果该参数没有指定,则将其设置为当前文档的 URL):

history.pushState(null, '', window.location);  //这里的URL参数为window.location

更复杂的情况可以参考本人之后转载的另一篇文章:点击iframe中的链接时,使用历史记录pushState更改父窗口的URL-CSDN博客

嵌入 iframe 的页面 history 流程(浏览器后退)

https://www.jianshu.com/p/4c7eb9534677/

 关于popState事件:

摘自:https://www.cnblogs.com/NaN-prototype/p/14308503.html

接下来,我们再说说标题所说的问题,如何判断页面是从刷新(重新加载)、正常打开(或链接打开)、还是从浏览器回退进入的?

过去可以直接使用以下方法,不过该方法利用的window.performance.navigation.type属性已经在新的标准中废弃,:

JS怎么判断页面是从前一个页面后退回来的 - 百度文库

可以参照以下该方法:

javascript - React - 如何检测页面刷新和重定向用户 - IT工具网

javascript - React - How to detect Page Refresh and Redirect user - Stack Overflow

参考资料:

https://developer.mozilla.org/en-US/docs/Web/API/PerformanceNavigationTiming/type

https://developer.mozilla.org/en-US/docs/Web/API/PerformanceNavigation/type

https://developer.mozilla.org/en-US/docs/Web/API/Performance

https://developer.mozilla.org/en-US/docs/Web/API/performance_property

https://developer.mozilla.org/zh-CN/docs/Web/API/performance_property

这篇关于javascritp如何判断是从刷新(重新加载)、正常打开(或链接打开)、还是从浏览器回退进入页面的?同时介绍iframe子页面切换时控制是否在浏览器中增加历史回退记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

javax.net.ssl.SSLHandshakeException:异常原因及解决方案

《javax.net.ssl.SSLHandshakeException:异常原因及解决方案》javax.net.ssl.SSLHandshakeException是一个SSL握手异常,通常在建立SS... 目录报错原因在程序中绕过服务器的安全验证注意点最后多说一句报错原因一般出现这种问题是因为目标服务器

CSS Anchor Positioning重新定义锚点定位的时代来临(最新推荐)

《CSSAnchorPositioning重新定义锚点定位的时代来临(最新推荐)》CSSAnchorPositioning是一项仍在草案中的新特性,由Chrome125开始提供原生支持需... 目录 css Anchor Positioning:重新定义「锚定定位」的时代来了! 什么是 Anchor Pos

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Python UV安装、升级、卸载详细步骤记录

《PythonUV安装、升级、卸载详细步骤记录》:本文主要介绍PythonUV安装、升级、卸载的详细步骤,uv是Astral推出的下一代Python包与项目管理器,主打单一可执行文件、极致性能... 目录安装检查升级设置自动补全卸载UV 命令总结 官方文档详见:https://docs.astral.sh/

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是