1. <ul id="0c1fb"></ul>

      <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
      <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区

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

      新聞中心

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

      本文小編為大家詳細介紹“Vue中怎么對iframe實現(xiàn)keep alive無刷新”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當(dāng),希望這篇“Vue中怎么對iframe實現(xiàn)keep alive無刷新”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。

      十余年的大竹網(wǎng)站建設(shè)經(jīng)驗,針對設(shè)計、前端、開發(fā)、售后、文案、推廣等六對一服務(wù),響應(yīng)快,48小時及時工作處理。全網(wǎng)營銷推廣的優(yōu)勢是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動調(diào)整大竹建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計,從而大程度地提升瀏覽體驗。創(chuàng)新互聯(lián)建站從事“大竹網(wǎng)站設(shè)計”,“大竹網(wǎng)站推廣”以來,每個客戶項目都認(rèn)真落實執(zhí)行。

      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頁可以做成 懶加載 ,只有在進入過相應(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無刷新”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。


      當(dāng)前標(biāo)題:Vue中怎么對iframe實現(xiàn)keepalive無刷新
      URL標(biāo)題:http://www.ef60e0e.cn/article/ghcgic.html
      99热在线精品一区二区三区_国产伦精品一区二区三区女破破_亚洲一区二区三区无码_精品国产欧美日韩另类一区
      1. <ul id="0c1fb"></ul>

        <noscript id="0c1fb"><video id="0c1fb"></video></noscript>
        <noscript id="0c1fb"><listing id="0c1fb"><thead id="0c1fb"></thead></listing></noscript>

        台中市| 德令哈市| 囊谦县| 姚安县| 伽师县| 沽源县| 门源| 通化县| 界首市| 遂溪县| 昆明市| 邯郸县| 廊坊市| 武夷山市| 色达县| 永丰县| 呼和浩特市| 安塞县| 神农架林区| 永吉县| 双鸭山市| 宜城市| 罗甸县| 十堰市| 枞阳县| 芦溪县| 临西县| 察隅县| 溧水县| 兴业县| 芦溪县| 临颍县| 北流市| 黄陵县| 元江| 宝兴县| 永昌县| 天峨县| 汉中市| 观塘区| 嘉义县|