Vue iframe更改src后页面未刷新问题解决方法

作者:NoSilverBullet 时间:2024-05-09 15:14:15 

一、场景描述

在项目开发过程中,应用iframe实现外系统页面嵌套的时候,发现引入其他页面后,页面内容并未刷新加载,经过一番研究,解决方案如下:

vm.iframeSrc = iframeSRC
if (document.getElementById('iframe')) {
setTimeout(() => {
document.getElementById(iframeid).contentWindow.location.reload(true);
}, 200)
}

注:务必在更改iframe src属性值之后补充页面重载逻辑,否则无法解决问题。

注:window.reload是重新加载当前需要的所有内容,也就包括页面和后台的代码,此过程中实际上是从后台重新进行操作;

二、高版本浏览器页签切换后内容不刷新问题解决

在应用上面的解决措施后,发现Chrome(>75)及IE高版本浏览器下,iframe在更改了src之后对应的网页并未刷新问题复现。

2.1 解决思路

iframe下页面内容未刷新问题其实是由于页面未重新渲染导致的,但是通过在src中添加时间戳以达到欺骗浏览器重新渲染的目的并未解决以上问题,后通过v-if实现销毁新建iframe方式,完美解决问题。

2.2 解决措施

<iframe v-if="flagsArr[index]" :src='...+timeStamp'></iframe>
handleSelect (tab, event) {
this.index = tab.index
this.flagsArr = Array(页签数组.length).fill(false)
this.flagsArr[this.index] = true
vm.iframeSrc = iframeSRC
if (document.getElementById('iframe')) {
setTimeout(() => {
document.getElementById(iframeid).contentWindow.location.reload(true);
}, 200)
}
}

三、拓展阅读

3.1 keep-alive 缓存 iframe

因为iframe不在vue的虚拟节点里,所以即使使用了vuekeep-alive也不会缓存iframe页面。

我们可以换个思路解决这个问题。首先在router.js里不要引入路径,就是component不写,这样会出现加载这个路由,页面是空白,然后在app.vue页面引入iframe的组件,在<roter-view />下面加载这个iframe组件,通过v-show判断$route.path === 'iframe的路由',如果是iframe页面,iframe页面就会正常加载出来,而且不管怎么跳转路由都会保存当前状态,也就相当于默认把iframe页面加载出来,只是通过display:none隐藏,如果到这个iframe路由下了,再让其显示。

来源:https://juejin.cn/post/7225645078403088421

标签:Vue,iframe,src后,页面,未刷新
0
投稿

猜你喜欢

  • 一文详解MySQL主从同步原理

    2024-01-24 03:00:59
  • 利用Python将list列表写入文件并读取的方法汇总

    2023-12-07 13:40:07
  • 利用canvas实现的加载动画效果实例代码

    2023-06-29 22:49:51
  • python中heapq堆排算法的实现

    2022-10-13 23:11:40
  • 基于Google的Python编码规范标准

    2023-02-21 12:40:38
  • Golang 中 omitempty的作用

    2024-04-25 15:13:03
  • TensorFlow2.0使用keras训练模型的实现

    2023-08-30 09:25:49
  • 分析在Python中何种情况下需要使用断言

    2022-01-03 12:36:44
  • 一文了解你不知道的JavaScript闭包篇

    2024-02-23 11:37:36
  • Python趣味挑战之实现简易版音乐播放器

    2021-06-25 15:13:43
  • Oracle删除字段中的空格、回车及指定字符的实例代码

    2024-01-18 18:10:07
  • Python实现快速排序的方法详解

    2022-08-29 13:08:35
  • Python tkinter实现桌面软件流程详解

    2022-03-26 09:51:32
  • W3C网页内容无障碍指南2.0(WCAG)

    2008-11-20 13:40:00
  • 交互设计杂七杂八

    2010-09-25 18:41:00
  • JavaScript检查数据中是否存在相同的元素(两种方法)

    2024-04-29 13:41:50
  • ASP函数验证带小数点数字格式

    2010-01-02 20:41:00
  • Python算术运算符实例详解

    2021-10-05 16:29:22
  • 系统默认的MySQL用户名消失的解决方法

    2008-12-02 14:26:00
  • 使用python3 实现插入数据到mysql

    2024-01-15 07:53:22
  • asp之家 网络编程 m.aspxhome.com