您好,登錄后才能下訂單哦!
這篇文章主要介紹了Vue iframe更改src后頁面未刷新問題如何解決的相關知識,內容詳細易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇Vue iframe更改src后頁面未刷新問題如何解決文章都會有所收獲,下面我們一起來看看吧。
在項目開發過程中,應用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
之后對應的網頁并未刷新問題復現。
iframe
下頁面內容未刷新問題其實是由于頁面未重新渲染導致的,但是通過在src
中添加時間戳以達到欺騙瀏覽器重新渲染的目的并未解決以上問題,后通過v-if
實現銷毀新建iframe
方式,完美解決問題。
<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) } }
因為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
路由下了,再讓其顯示。
關于“Vue iframe更改src后頁面未刷新問題如何解決”這篇文章的內容就介紹到這里,感謝各位的閱讀!相信大家對“Vue iframe更改src后頁面未刷新問題如何解決”知識都有一定的了解,大家如果還想學習更多知識,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。