摘要:前言最近一個(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
摘要:前言最近一個(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)有用,于是自己研究了...
摘要:如果要相應(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/...
摘要:如果要相應(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/...
摘要:如果要相應(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/...
摘要:用開(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é)完,下下篇可...
閱讀 959·2023-04-25 23:50
閱讀 1970·2021-11-19 09:40
閱讀 602·2019-08-30 13:50
閱讀 2731·2019-08-29 17:11
閱讀 1046·2019-08-29 16:37
閱讀 2990·2019-08-29 12:54
閱讀 2798·2019-08-28 18:17
閱讀 2641·2019-08-26 16:55