国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專(zhuān)欄INFORMATION COLUMN

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

heartFollower / 1638人閱讀

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

前言

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

Vue的keep-alive原理

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

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

既然保持iframe頁(yè)里的狀態(tài)很難實(shí)現(xiàn),在這個(gè)時(shí)候我想到了一個(gè)別的方法。能否在Vue的route-view節(jié)點(diǎn)上動(dòng)點(diǎn)手腳?使得在切換非iframe頁(yè)的時(shí)候使用Vue的路由,當(dāng)切換iframe頁(yè)時(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è)頁(yè)面 { path: "/f1", name: "f1" }, // 含有iframe的兩個(gè)頁(yè)面 { 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)單來(lái)說(shuō),關(guān)鍵的地方首先是main.js初始化路由時(shí),對(duì)iframe頁(yè)不填寫(xiě)屬性component,這樣頁(yè)面就是空白的。然后在router-view節(jié)點(diǎn)旁邊渲染iframe頁(yè)組件,使用$route.path判斷當(dāng)前路由的指向,控制iframe頁(yè)的顯示與隱藏

優(yōu)化

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

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

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

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

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

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

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



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

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

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

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

結(jié)語(yǔ)

大家如果有更好的實(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://specialneedsforspecialkids.com/yun/54259.html

相關(guān)文章

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

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

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

    摘要:如果要相應(yīng)狀態(tài)改變,通常最好使用計(jì)算屬性或取而代之。那解決問(wèn)題的思路便是在改變的情況下,保證頁(yè)面的不刷新。后面值的變化,并不會(huì)導(dǎo)致瀏覽器向服務(wù)器發(fā)出請(qǐng)求,瀏覽器不發(fā)出請(qǐng)求,也就不會(huì)刷新頁(yè)面。 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
  • 面試官常問(wèn)——vue

    摘要:如果要相應(yīng)狀態(tài)改變,通常最好使用計(jì)算屬性或取而代之。那解決問(wèn)題的思路便是在改變的情況下,保證頁(yè)面的不刷新。后面值的變化,并不會(huì)導(dǎo)致瀏覽器向服務(wù)器發(fā)出請(qǐng)求,瀏覽器不發(fā)出請(qǐng)求,也就不會(huì)刷新頁(yè)面。 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
  • 面試官常問(wèn)——vue

    摘要:如果要相應(yīng)狀態(tài)改變,通常最好使用計(jì)算屬性或取而代之。那解決問(wèn)題的思路便是在改變的情況下,保證頁(yè)面的不刷新。后面值的變化,并不會(huì)導(dǎo)致瀏覽器向服務(wù)器發(fā)出請(qǐng)求,瀏覽器不發(fā)出請(qǐng)求,也就不會(huì)刷新頁(yè)面。 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開(kāi)發(fā)仿旅游站webapp項(xiàng)目總結(jié) (下)

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

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

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

0條評(píng)論

heartFollower

|高級(jí)講師

TA的文章

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