Vue iframe更改src后页面未刷新问题解决
【摘要】 一、场景描述在项目开发过程中,应用iframe实现外系统页面嵌套的时候,发现引入其他页面后,页面内容并未刷新加载,经过一番研究,解决方案如下:vm.iframeSrc = iframeSRCif (document.getElementById('iframe')) { setTimeout(() => { document.getElementById(iframeid).conten...
一、场景描述
在项目开发过程中,应用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
的虚拟节点里,所以即使使用了vue
的keep-alive
也不会缓存iframe
页面。
我们可以换个思路解决这个问题。首先在router.js
里不要引入路径,就是component
不写,这样会出现加载这个路由,页面是空白,然后在app.vue
页面引入iframe
的组件,在<roter-view />
下面加载这个iframe
组件,通过v-show
判断$route.path === 'iframe的路由'
,如果是iframe
页面,iframe
页面就会正常加载出来,而且不管怎么跳转路由都会保存当前状态,也就相当于默认把iframe
页面加载出来,只是通过display:none
隐藏,如果到这个iframe
路由下了,再让其显示。
【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
作者其他文章
评论(0)