我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

一、场景描述

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

vm.iframeclass="lazy" data-src = iframeclass="lazy" data-src
if (document.getElementById('iframe')) {
	setTimeout(() => {
		document.getElementById(iframeid).contentWindow.location.reload(true);
	}, 200)
}

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

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

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

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

2.1 解决思路

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

2.2 解决措施

<iframe v-if="flagsArr[index]" :class="lazy" data-src='...+timeStamp'></iframe>
handleSelect (tab, event) {
	this.index = tab.index
	this.flagsArr = Array(页签数组.length).fill(false)
	this.flagsArr[this.index] = true
	vm.iframeclass="lazy" data-src = iframeclass="lazy" data-src
	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路由下了,再让其显示。

到此这篇关于Vue iframe更改class="lazy" data-src后页面未刷新问题解决的文章就介绍到这了,更多相关Vue iframe更改class="lazy" data-src后页面未刷新内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

这篇文章主要介绍了Vueiframe更改src后页面未刷新问题解决,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2023-05-18

vue中内嵌iframe的src更新页面未刷新问题及解决

这篇文章主要介绍了vue中内嵌iframe的src更新页面未刷新问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-09

vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法

VueRouter嵌套路由在History模式下刷新无法渲染页面的解决方法:使用Vuex管理路由状态:在store中保存路由路径,刷新后恢复它。使用HTML5HistoryAPI:用pushState()更新URL哈希,刷新后使用window.location.hash获取更新后的哈希。使用VueRouter的keepAlive:缓存嵌套组件实例,防止刷新后销毁。示例:使用Vuex管理路由状态的方法。
vue router嵌套路由在history模式下刷新无法渲染页面问题的解决方法
2024-04-25

修改织梦DedeCMS广告模块后,前台显示未更新的解决方法

安装了 Dedecms 自带的广告模块后,发现在修改广告信息后,前台调用的广告还是修改之前的信息,查看了一下源代码,发现是调用缓存了,但是 DedeCMS 的 ad_edit.php 编辑保存信息后又没有删除原来的缓存,小bug一枚,这里修
2022-06-12

Vue项目部署到IIS后刷新报错404的问题及解决方法

这篇文章主要介绍了Vue项目部署到IIS后,刷新报错404,这里需要用到URL重写工具 --URL Rewrite,需要的话需要自己下载安装,本文通过图文并茂的形式给大家介绍的非常详细,需要的朋友可以参考下
2022-11-13

Win11在安装 KB5026446 更新后出现多种问题的解决方法

Windows 11 上个月推送了 KB5026446,其中包含切换到 Windows 11 Moment 3 的配置更新,但随着新功能一同而来的还有许多 Bug。tAiClLq但现在最大的问题是,很多用户反馈称php当你检查更新时会自动安
2023-06-05

Win10更新后页面卡死和多任务打开错误窗口的解决方法

这篇文章给大家分享的是有关Win10更新后页面卡死和多任务打开错误窗口的解决方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。虽然 Windows 10 October 2020(20H2)功能更新相对来说已比较
2023-06-10

ecshop伪静态后产品列表页切换显示方式无法打开页面的解决问题

theme/default/library/goods_list.lbi 在你的FTP里找到这个库文件,这里以default默认模板为例子编程客栈,其他的请编程客栈到各自模板文件夹下找,然后找到下面这段代码
2022-06-12

编程热搜

目录