uniapp h5项目页面中使用了iframe导致浏览器返回按键无法使用, 返回不了上一页.

uniapp h5项目页面中使用了iframe导致浏览器返回按键无法使用, 返回不了上一页.

在 UniApp 中使用 iframe 加载外部页面时,可能会遇到返回键行为不符合预期的问题。这是因为 iframe 本身可以包含多个页面的历史记录,而默认情况下,浏览器的返回键会控制 iframe 内部页面的历史记录,而不是外部页面的历史记录。

解决方案(禁用 iframe 的历史记录)

html 复制代码
<template>

  <view>

    <iframe ref="myIframe" :src="iframeSrc" frameborder="0" @load="onIframeLoad"></iframe>

  </view>

</template>


<script>

export default {

  data() {

    return {
      iframeSrc: 'http://example.com',
    };

  },

  methods: {

    onIframeLoad(event) {
	  if(this.$refs.myIframe.contentWindow){
		// 禁用 iframe 中的历史记录
		this.$refs.myIframe.contentWindow.history.pushState({}, '');
		this.$refs.myIframe.contentWindow.onpopstate = (event) => {
			event.preventDefault();
			// 跳转到上一页
			uni.switchTab({
				url: "/pages/index/index",
			});
		};
	  }
    },
  }
};

</script>
相关推荐
锋行天下8 分钟前
公司内网部署大模型的探索之路
前端·人工智能·后端
1024肥宅1 小时前
手写 EventEmitter:深入理解发布订阅模式
前端·javascript·eventbus
海市公约2 小时前
HTML网页开发从入门到精通:从标签到表单的完整指南
前端·ide·vscode·程序人生·架构·前端框架·html
行云流水6263 小时前
前端树形结构实现勾选,半勾选,取消勾选。
前端·算法
diudiu_333 小时前
web漏洞--认证缺陷
java·前端·网络
阿珊和她的猫3 小时前
<video>` 和 `<audio>` 标签的常用属性解析
前端
LSL666_4 小时前
4 jQuery、JavaScript 作用域、闭包与 DOM 事件绑定
前端·javascript·html
yinuo4 小时前
前端跨页面通讯终极指南⑤:window.name 用法全解析
前端
小飞侠在吗4 小时前
vue computed 和 watch
前端·javascript·vue.js
yinuo4 小时前
前端跨页面通讯终极指南④:MessageChannel 用法全解析
前端