最近2018中文字幕在日韩欧美国产成人片_国产日韩精品一区二区在线_在线观看成年美女黄网色视频_国产精品一区三区五区_国产精彩刺激乱对白_看黄色黄大色黄片免费_人人超碰自拍cao_国产高清av在线_亚洲精品电影av_日韩美女尤物视频网站

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Vue中對iframe實現(xiàn)keepalive無刷新的示例分析-創(chuàng)新互聯(lián)

這篇文章主要介紹Vue中對iframe實現(xiàn)keep alive無刷新的示例分析,文中介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們一定要看完!

讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:空間域名、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設(shè)、赤壁網(wǎng)站維護(hù)、網(wǎng)站推廣。

Vue的keep-alive原理

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

實現(xiàn)的思路

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

我們簡陋的實現(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的兩個頁面  {  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')

根組件:



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

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

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

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

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

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

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

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

main.js:

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

const routes = [
 {
 path: '/f1',
 name: 'f1',
 iframeComponent: F1 // 用于標(biāo)識是否含有iframe頁
 },
 {
 path: '/f2',
 name: 'f2',
 iframeComponent: F2 // 用于標(biāo)識是否含有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:



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

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

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

以上是“Vue中對iframe實現(xiàn)keep alive無刷新的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


當(dāng)前標(biāo)題:Vue中對iframe實現(xiàn)keepalive無刷新的示例分析-創(chuàng)新互聯(lián)
文章分享:http://fisionsoft.com.cn/article/csejeo.html