亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Vue中對iframe實現keep alive無刷新的方法

2019-11-19 11:09:10
字體:
來源:轉載
供稿:網友

前言

最近一個需求,需要在 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頁的 顯示與隱藏 。

上面代碼簡單的解決了問題,但還有一些地方可以優化:

  1. iframe頁在根節點App.vue一渲染時 已經渲染 了,對此iframe頁可以做成 懶加載 ,只有在進入過相應頁面了觸發渲染,并且渲染過之后就用v-show切換顯示與隱藏
  2. 每當增加一個iframe頁都要增加一段的組件引入注冊和調用的代碼。比較 繁瑣 。我們目標應該做到每增加一個iframe頁,只需要添加盡量少的代碼。這里思路是:
    1. 在路由配置中定義一個屬性,用于 標識該頁面是否含有iframe 的頁面
    2. 根據標識,iframe頁組件 自動動態注冊和渲染 ,無需再手寫額外的代碼
    3. router-view和iframe切換的邏輯封裝成 新組件 ,用它 替代原有的router-view

我們先修改router的配置,增加一個屬性名iframeComponent,用于標識是否包含iframe,該屬性的值是組件文件引用

main.js:

import F1 from './components/f1';import F2 from './components/f2';const routes = [ { path: '/f1', name: 'f1', iframeComponent: F1 // 用于標識是否含有iframe頁 }, { path: '/f2', name: 'f2', iframeComponent: F2 // 用于標識是否含有iframe頁 }, { path: '/index', component: { template: '<div>Index</div>' } }]const router = new VueRouter({ routes // (縮寫)相當于 routes: routes});new Vue({ render: h => h(App), router}).$mount('#app')

接下來我們第二步和第三步結合在一起,封裝新的組件iframe-router-view.vue:

<template> <div>  <!-- Vue的router-view -->  <keep-alive>   <router-view></router-view>  </keep-alive>  <!-- iframe頁 -->  <component   v-for="item in hasOpenComponentsArr"   :key="item.name"   :is="item.name"   v-show="$route.path === item.path"  ></component> </div></template><script>import Vue from 'vue/dist/vue.js'export default { created() {  // 設置iframe頁的數組對象  const componentsArr = this.getComponentsArr();  componentsArr.forEach((item) => {   Vue.component(item.name, item.component);  });  this.componentsArr = componentsArr;  // 判斷當前路由是否iframe頁  this.isOpenIframePage(); }, data() {  return {   componentsArr: [] // 含有iframe的頁面  } }, watch: {  $route() {   // 判斷當前路由是否iframe頁   this.isOpenIframePage();  } }, computed: {  // 實現懶加載,只渲染已經打開過(hasOpen:true)的iframe頁  hasOpenComponentsArr() {   return this.componentsArr.filter(item => item.hasOpen);  } }, methods: {  // 根據當前路由設置hasOpen  isOpenIframePage() {   const target = this.componentsArr.find(item => {    return item.path === this.$route.path   });   if (target && !target.hasOpen) {    target.hasOpen = true;   }  },  // 遍歷路由的所有頁面,把含有iframeComponent標識的收集起來  getComponentsArr() {   const router = this.$router;   const routes = router.options.routes;   const iframeArr = routes.filter(item => item.iframeComponent);      return iframeArr.map((item) => {    const name = item.name || item.path.replace('/', '');    return {     name: name,     path: item.path,     hasOpen: false, // 是否打開過,默認false     component: item.iframeComponent // 組件文件的引用    };   });  } }}</script>
  1. 該組件主要做的是根據main.ja里的routes生成一個只含有iframe頁的數組對象。
  2. watch上監聽$route,判斷當前頁面在iframe頁列表里的話就設置hasOpen屬性為true,渲染該組件
  3. 用v-show="$route.path === item.path"切換iframe頁的顯示與隱藏。

邏輯并不復雜,這里就不多贅述。

結語

大家如果有更好的實現方法,或者我上面還有什么需要更正的錯誤,歡迎交流。 上面demo的代碼放在了個人github上 https://github.com/jmx164491960/vue-iframe-demo

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品电影网站| 久久影视免费观看| 日日骚久久av| 成人久久久久爱| 成人av资源在线播放| 国产一区二区三区四区福利| www.亚洲一区| 亚洲iv一区二区三区| 国产精品最新在线观看| 国产精品一区二区久久久| 成人久久精品视频| 高跟丝袜欧美一区| 亚洲经典中文字幕| 欧美一区二区大胆人体摄影专业网站| 九色精品美女在线| 国产欧美精品在线| 欧美日韩不卡合集视频| 性欧美办公室18xxxxhd| 久久久久久久一区二区三区| 国产精品国产三级国产aⅴ浪潮| 精品久久久一区| 91精品视频网站| 日韩综合视频在线观看| 成人欧美一区二区三区在线湿哒哒| 亚洲人永久免费| 97久久精品人搡人人玩| 中文字幕欧美日韩va免费视频| 九九热这里只有在线精品视| 亚洲国产天堂久久国产91| 亚洲欧美国产一区二区三区| 色哟哟亚洲精品一区二区| 日韩av影视在线| 日韩在线不卡视频| 欧美另类精品xxxx孕妇| 亚洲第一在线视频| 俺去了亚洲欧美日韩| 中文字幕国产精品| 欧美成人午夜剧场免费观看| 国产不卡av在线| 亚洲第一精品自拍| 久久网福利资源网站| 成人情趣片在线观看免费| 国产女同一区二区| 亚洲国产精久久久久久久| 欧美精品在线观看91| 日韩精品视频在线| 久久久久久中文字幕| 91在线观看免费网站| 亚洲视频自拍偷拍| 久久视频在线观看免费| 久久九九国产精品怡红院| 奇米影视亚洲狠狠色| 亚洲天堂av女优| 日韩在线观看电影| 欧美成在线观看| 欧美高清视频在线观看| 成人福利网站在线观看11| 欧美福利视频在线观看| 亚洲精品成人久久久| 中文字幕在线看视频国产欧美在线看完整| 欧美国产精品va在线观看| 亚洲国产另类 国产精品国产免费| 亚洲人精品午夜在线观看| 国产一区二区视频在线观看| 国产精品青青在线观看爽香蕉| 日韩电影免费观看中文字幕| 亚洲一区久久久| 国产极品精品在线观看| 亚洲国产精久久久久久| 欧美日韩国产综合视频在线观看中文| 日韩视频在线免费观看| 欧美野外wwwxxx| 国产日韩精品在线播放| 中文字幕日韩欧美精品在线观看| 亚洲成人在线视频播放| 亚洲а∨天堂久久精品喷水| 91av福利视频| 青青精品视频播放| 成人在线一区二区| 国产精品精品视频一区二区三区| 欧洲永久精品大片ww免费漫画| 国产精品视频不卡| 欧美国产在线视频| 欧美性猛交xxxx黑人猛交| 久久久久九九九九| 国产日韩欧美电影在线观看| 亚洲日本欧美日韩高观看| 在线看欧美日韩| 欧美精品在线第一页| 国产精品成人免费视频| 中文字幕9999| 久久99精品久久久久久青青91| 国产精品视频不卡| 国产剧情久久久久久| 精品久久久久久久久久| 欧美色欧美亚洲高清在线视频| 在线视频欧美日韩| 97视频com| 国产亚洲视频中文字幕视频| y97精品国产97久久久久久| 欧美性受xxxx黑人猛交| 日韩av影院在线观看| 2018中文字幕一区二区三区| 欧美日韩在线另类| 日韩欧美在线视频日韩欧美在线视频| 精品中文字幕在线2019| 久久精品一偷一偷国产| 亚洲天堂成人在线视频| 日韩欧美在线视频日韩欧美在线视频| 欧美一级淫片丝袜脚交| 欧美黄色小视频| 日韩国产中文字幕| 久久最新资源网| 日韩av黄色在线观看| 久久综合九色九九| 欧美电影院免费观看| 国产亚洲一区精品| 久久久久五月天| 日韩欧美极品在线观看| 欧美日韩在线免费观看| 国产精品91在线| 91精品一区二区| 精品久久久久久久久久久久久久| 青草青草久热精品视频在线观看| 国产成人精品在线观看| 国产欧美一区二区白浆黑人| 日韩中文视频免费在线观看| 97精品久久久中文字幕免费| 欧美老女人在线视频| 成人网欧美在线视频| 国产精品一区二区3区| 亚洲欧美精品在线| 欧美日韩在线免费| 日韩美女av在线| 亚洲欧美激情四射在线日| 国产精品毛片a∨一区二区三区|国| 91精品视频网站| 成人精品视频久久久久| 韩国日本不卡在线| 日韩欧美一区二区在线| 91精品啪aⅴ在线观看国产| 精品国产一区二区三区久久狼5月| 日韩精品视频在线免费观看| 日韩在线中文字幕| 69国产精品成人在线播放| 久久精品国产欧美激情| 亚洲三级黄色在线观看| 成人免费在线视频网址| 久久99久国产精品黄毛片入口| 欧美老少配视频| 亚洲欧美日韩精品久久奇米色影视| 日韩美女在线观看一区| 国产精品成人观看视频国产奇米| 97热在线精品视频在线观看| 中文字幕视频在线免费欧美日韩综合在线看| 韩国精品美女www爽爽爽视频| 91九色国产视频| 成人妇女淫片aaaa视频| 亚洲天堂男人天堂| 久久久人成影片一区二区三区观看| 日本精品视频在线观看| 久久精品这里热有精品| 法国裸体一区二区| 91在线视频成人|