Vue?iframe更改src后页面未刷新问题如何解决


这篇文章主要介绍了Vueiframe更改src后页面未刷新问题如何解决的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vueiframe更改src后页面未刷新问题如何解决文章都会有所收获,下面我们一起来看看吧。

一、场景描述

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

vm.iframeSrc=iframeSRCif(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 解决措施

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

三、拓展阅读

keep-alive 缓存 iframe

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

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

关于“Vueiframe更改src后页面未刷新问题如何解决”这篇文章的内容就介绍到这里,感谢各位的阅读!相信大家对“Vueiframe更改src后页面未刷新问题如何解决”知识都有一定的了解,大家如果还想学习更多知识,欢迎关注主机评测网行业资讯频道。


上一篇:vue2怎么让数组也变成响应式

下一篇:phpcms数据表结构和字段有哪些


Copyright © 2002-2019 测速网 www.inhv.cn 皖ICP备2023010105号
测速城市 测速地区 测速街道 网速测试城市 网速测试地区 网速测试街道
温馨提示:部分文章图片数据来源与网络,仅供参考!版权归原作者所有,如有侵权请联系删除!

热门搜索 城市网站建设 地区网站制作 街道网页设计 大写数字 热点城市 热点地区 热点街道 热点时间 房贷计算器