成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Vue中對(duì)iframe實(shí)現(xiàn)keep alive(無刷新)

heartFollower / 1640人閱讀

摘要:前言最近一個(gè)需求,需要在項(xiàng)目中加入含有的頁面,同時(shí)在路由切換的過程中,要求的內(nèi)容不會(huì)被刷新。的原理要實(shí)現(xiàn)對(duì)保持頁的狀態(tài)。實(shí)現(xiàn)的思路既然保持頁里的狀態(tài)很難實(shí)現(xiàn),在這個(gè)時(shí)候我想到了一個(gè)別的方法。

前言

最近一個(gè)需求,需要在Vue項(xiàng)目中加入含有iframe的頁面,同時(shí)在路由切換的過程中,要求iframe的內(nèi)容不會(huì)被刷新。一開始使用了Vue自帶的keep- alive發(fā)現(xiàn)沒有用,于是自己研究了一下解決方案。。。。。。

Vue的keep-alive原理

要實(shí)現(xiàn)對(duì)保持iframe頁的狀態(tài)。我們先搞清楚為什么Vue的keep-alive不能湊效。keep-alive原理是把組件里的節(jié)點(diǎn)信息保留在了VNode(在內(nèi)存里),在需要渲染時(shí)候從Vnode渲染到真實(shí)DOM上。iframe頁里的內(nèi)容并不屬于節(jié)點(diǎn)的信息,所以使用keep-alive依然會(huì)重新渲染iframe內(nèi)的內(nèi)容。另外,我也嘗試有過想法:如果把整個(gè)iframe節(jié)點(diǎn)保存起來,然后需要切換時(shí)把它渲染到目標(biāo)節(jié)點(diǎn)上,能否實(shí)現(xiàn)iframe頁不被刷新呢?————也是不可行的,iframe每一次渲染就相當(dāng)于打開一個(gè)新的網(wǎng)頁窗口,即使把節(jié)點(diǎn)保存下來,在渲染時(shí)iframe頁還是刷新的。

實(shí)現(xiàn)的思路

既然保持iframe頁里的狀態(tài)很難實(shí)現(xiàn),在這個(gè)時(shí)候我想到了一個(gè)別的方法。能否在Vue的route-view節(jié)點(diǎn)上動(dòng)點(diǎn)手腳?使得在切換非iframe頁的時(shí)候使用Vue的路由,當(dāng)切換iframe頁時(shí)則使用v-show切換顯示與隱藏,使得iframe節(jié)點(diǎn)一直不被刪除,這樣就能保持iframe的狀態(tài)了。

我們簡(jiǎn)陋的實(shí)現(xiàn)一下以上的效果,上代碼:

入口main.js:

import Vue from "vue/dist/vue.js"
import App from "./App.vue"
import VueRouter from "vue-router";

const Index = { template: "
Index
" } const routes = [ // 含有iframe的兩個(gè)頁面 { path: "/f1", name: "f1" }, // 含有iframe的兩個(gè)頁面 { 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")

根組件:



上面代碼簡(jiǎn)單來說,關(guān)鍵的地方首先是main.js初始化路由時(shí),對(duì)iframe頁不填寫屬性component,這樣頁面就是空白的。然后在router-view節(jié)點(diǎn)旁邊渲染iframe頁組件,使用$route.path判斷當(dāng)前路由的指向,控制iframe頁的顯示與隱藏。

優(yōu)化

上面代碼簡(jiǎn)單的解決了問題,但還有一些地方可以優(yōu)化:

iframe頁在根節(jié)點(diǎn)App.vue一渲染時(shí)已經(jīng)渲染了,對(duì)此iframe頁可以做成懶加載,只有在進(jìn)入過相應(yīng)頁面了觸發(fā)渲染,并且渲染過之后就用v-show切換顯示與隱藏

每當(dāng)增加一個(gè)iframe頁都要增加一段的組件引入注冊(cè)和調(diào)用的代碼。比較繁瑣。我們目標(biāo)應(yīng)該做到每增加一個(gè)iframe頁,只需要添加盡量少的代碼。這里思路是:

在路由配置中定義一個(gè)屬性,用于標(biāo)識(shí)該頁面是否含有iframe的頁面

根據(jù)標(biāo)識(shí),iframe頁組件自動(dòng)動(dòng)態(tài)注冊(cè)和渲染,無需再手寫額外的代碼

router-view和iframe切換的邏輯封裝成新組件,用它替代原有的router-view

我們先修改router的配置,增加一個(gè)屬性名iframeComponent,用于標(biāo)識(shí)是否包含iframe,該屬性的值是組件文件引用

main.js:

import F1 from "./components/f1";
import F2 from "./components/f2";

const routes = [
  {
    path: "/f1",
    name: "f1",
    iframeComponent: F1 // 用于標(biāo)識(shí)是否含有iframe頁
  },
  {
    path: "/f2",
    name: "f2",
    iframeComponent: F2 // 用于標(biāo)識(shí)是否含有iframe頁
  },
  {
    path: "/index",
    component: { template: "
Index
" } } ] const router = new VueRouter({ routes // (縮寫)相當(dāng)于 routes: routes }); new Vue({ render: h => h(App), router }).$mount("#app")

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



該組件主要做的是根據(jù)main.ja里的routes生成一個(gè)只含有iframe頁的數(shù)組對(duì)象。

watch上監(jiān)聽$route,判斷當(dāng)前頁面在iframe頁列表里的話就設(shè)置hasOpen屬性為true,渲染該組件

用v-show="$route.path === item.path"切換iframe頁的顯示與隱藏。

邏輯并不復(fù)雜,這里就不多贅述。

結(jié)語

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

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/54259.html

相關(guān)文章

  • Vue中對(duì)iframe實(shí)現(xiàn)keep alive刷新

    摘要:前言最近一個(gè)需求,需要在項(xiàng)目中加入含有的頁面,同時(shí)在路由切換的過程中,要求的內(nèi)容不會(huì)被刷新。的原理要實(shí)現(xiàn)對(duì)保持頁的狀態(tài)。實(shí)現(xiàn)的思路既然保持頁里的狀態(tài)很難實(shí)現(xiàn),在這個(gè)時(shí)候我想到了一個(gè)別的方法。 前言 最近一個(gè)需求,需要在Vue項(xiàng)目中加入含有iframe的頁面,同時(shí)在路由切換的過程中,要求iframe的內(nèi)容不會(huì)被刷新。一開始使用了Vue自帶的keep- alive發(fā)現(xiàn)沒有用,于是自己研究了...

    k00baa 評(píng)論0 收藏0
  • 面試官常問——vue

    摘要:如果要相應(yīng)狀態(tài)改變,通常最好使用計(jì)算屬性或取而代之。那解決問題的思路便是在改變的情況下,保證頁面的不刷新。后面值的變化,并不會(huì)導(dǎo)致瀏覽器向服務(wù)器發(fā)出請(qǐng)求,瀏覽器不發(fā)出請(qǐng)求,也就不會(huì)刷新頁面。 1.vue生命周期2.vue 雙向綁定原理3.vue router原理4.vue router動(dòng)態(tài)路由 1.vue 生命周期鉤子 showImg(https://segmentfault.com/...

    BlackMass 評(píng)論0 收藏0
  • 面試官常問——vue

    摘要:如果要相應(yīng)狀態(tài)改變,通常最好使用計(jì)算屬性或取而代之。那解決問題的思路便是在改變的情況下,保證頁面的不刷新。后面值的變化,并不會(huì)導(dǎo)致瀏覽器向服務(wù)器發(fā)出請(qǐng)求,瀏覽器不發(fā)出請(qǐng)求,也就不會(huì)刷新頁面。 1.vue生命周期2.vue 雙向綁定原理3.vue router原理4.vue router動(dòng)態(tài)路由 1.vue 生命周期鉤子 showImg(https://segmentfault.com/...

    xingqiba 評(píng)論0 收藏0
  • 面試官常問——vue

    摘要:如果要相應(yīng)狀態(tài)改變,通常最好使用計(jì)算屬性或取而代之。那解決問題的思路便是在改變的情況下,保證頁面的不刷新。后面值的變化,并不會(huì)導(dǎo)致瀏覽器向服務(wù)器發(fā)出請(qǐng)求,瀏覽器不發(fā)出請(qǐng)求,也就不會(huì)刷新頁面。 1.vue生命周期2.vue 雙向綁定原理3.vue router原理4.vue router動(dòng)態(tài)路由 1.vue 生命周期鉤子 showImg(https://segmentfault.com/...

    quietin 評(píng)論0 收藏0
  • Vue開發(fā)仿旅游站webapp項(xiàng)目總結(jié) (下)

    摘要:用開發(fā)仿旅游站項(xiàng)目總結(jié)上該說的話,該表明的上篇已經(jīng)表明了。之后的路由切換不再請(qǐng)求數(shù)據(jù)是因?yàn)榻M件內(nèi)容是從內(nèi)存取了不會(huì)再重新創(chuàng)建了,對(duì)應(yīng)的鉤子函數(shù)不會(huì)再執(zhí)行了。此時(shí),通過新增的生命周期鉤子函數(shù)以及這個(gè)緩存值就實(shí)現(xiàn)了我們要的功能了。 用Vue開發(fā)仿旅游站webapp項(xiàng)目總結(jié) (上)該說的話,該表明的上篇已經(jīng)表明了。謝謝上篇評(píng)論區(qū)一些同學(xué)~ 很鼓勵(lì)我,不過下下篇估計(jì)沒了,這篇總結(jié)完,下下篇可...

    libxd 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

heartFollower

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<