前言
最近一個需求,需要在 Vue 項目中加入 含有iframe 的頁面,同時在路由切換的過程中,要求iframe的內容 不會被刷新 。一開始使用了Vue自帶的keep- alive發現沒有用,于是自己研究了一下解決方案。。。。。。
Vue的keep-alive原理
要實現對保持iframe頁的狀態。我們先搞清楚為什么Vue的keep-alive不能湊效。keep-alive原理是把組件里的節點信息保留在了 VNode (在內存里),在需要渲染時候從Vnode渲染到真實DOM上。iframe頁里的內容并不屬于節點的信息,所以使用keep-alive依然會重新渲染iframe內的內容。 另外 ,我也嘗試有過想法:如果把整個iframe節點保存起來,然后需要切換時把它渲染到目標節點上,能否實現iframe頁不被刷新呢?————也是不可行的,iframe每一次渲染就相當于打開一個新的網頁窗口,即使把節點保存下來,在渲染時iframe頁還是刷新的。
實現的思路
既然保持iframe頁里的狀態很難實現,在這個時候我想到了一個別的方法。能否在Vue的route-view節點上動點手腳?使得在切換 非iframe頁 的時候使用Vue的路由,當切換 iframe頁 時則使用 v-show 切換顯示與隱藏,使得iframe節點 一直不被刪除 ,這樣就能保持iframe的狀態了。
我們簡陋的實現一下以上的效果,上代碼:
入口main.js:
import Vue from 'vue/dist/vue.js'import App from './App.vue'import VueRouter from 'vue-router';const Index = { template: '<div>Index</div>' }const routes = [ // 含有iframe的兩個頁面 { path: '/f1', name: 'f1' }, // 含有iframe的兩個頁面 { path: '/f2', name: 'f2' }, { path: '/index', component: Index }]const router = new VueRouter({ routes});Vue.use(VueRouter);new Vue({ render: h => h(App), router}).$mount('#app')根組件:
<template> <div id="app"> <div class="nav"> <router-link class="router" to="/f1">Go to F1</router-link> <router-link class="router" to="/f2">Go to F2</router-link> <router-link class="router" to="/index">Go to Index</router-link> </div> <keep-alive> <!-- Vue的路由 --> <router-view></router-view> </keep-alive> <!-- iframe頁面 --> <f1 v-show="$route.path == '/f1'"></f1> <f2 v-show="$route.path == '/f2'"></f2> </div></template><script>import F1 from './components/f1';import F2 from './components/f2';export default { name: 'app', components: { F1, F2 }, }</script>上面代碼簡單來說,關鍵的地方首先是main.js初始化路由時,對iframe頁不填寫屬性component,這樣頁面就是空白的。然后在 router-view 節點旁邊渲染iframe頁組件,使用$route.path判斷當前路由的指向,控制iframe頁的 顯示與隱藏 。
新聞熱點
疑難解答
圖片精選