欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

vueTab切換以及緩存頁面處理的幾種方式

前言

創(chuàng)新互聯(lián)建站專注于企業(yè)營銷型網(wǎng)站、網(wǎng)站重做改版、三明網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、成都h5網(wǎng)站建設(shè)、商城系統(tǒng)網(wǎng)站開發(fā)、集團公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為三明等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。

相信tab切換對于大家來說都不算陌生,后臺管理系統(tǒng)中多會用到。如果不知道的話,可以看一下瀏覽器上方的標簽頁切換,大概效果就是這樣。

1.如何切換

使用動態(tài)組件,相信大家都能看懂(部分代碼省略)

//通過點擊就可以實現(xiàn)兩個組件來回切換
<button @click="changeView">切換view</button>
<component :is="currentView"></component>

import pageA from "@/views/pageA";
import pageB from "@/views/pageB";

computed: {
 currentView(){
   return this.viewList[this.index];
 }
},
 methods: {
 changeView() {
  this.index=(++this.index)%2
 }
}
注:這個多用于單頁下的幾個子模塊使用,一般切換比較多使用下面的路由

使用路由(這個就是配置路由的問題了,不作贅述)2.動態(tài)生成tab

一般UI框架給我們的tab切換都像是上面的那種,需要自己寫入幾個tab頁之類的配置。但是我們?nèi)绻胍ㄟ^點擊左邊的目錄來生成一個tab頁并且可以隨時關(guān)閉呢(如下圖)?

vue Tab切換以及緩存頁面處理的幾種方式

只需要給路由一個點擊事件,把你的路由地址保存到一個列表,渲染成另一個平鋪的tab目錄即可

假設(shè)你的布局是這樣,左邊的目錄,上邊的tab,有字的是頁面

vue Tab切換以及緩存頁面處理的幾種方式

<menu>
 <menu-item v-for="(item,index) in menuList" :key="index" @click="addToTabList(item.path)">
  <router-link :to="item.path">{{item.name}}</router-link>
 <menu-item>
</menu>
<template>
 <menu class="left"/>//menu代碼部分如上
 <div class="right">
  <tab-list>
   <tab-item v-for="(item,index) in tabList" :key="index">
    <router-link :to="item.path">{{item.name}}</router-link>
    <icon class="delete" @click="deleteTab"></icon>
   </tab-item>
  </tab-list>
  <page-view>
   <router-view></router-view>//這里是頁面展示
  </page-view>
 </div>
</template>
以上代碼并非實際代碼,只提供一個大概的思路。至于addToTabListdeleteTab怎么做就是數(shù)組方法的簡單pushsplice操作了。為了效果好看,我們可能還需要一些tabactive樣式,這里不作演示。

3.緩存組件

僅僅是做tab切換,遠遠是不夠的,畢竟大家想要tab頁就是要來回切換操作,我們需要保存他在不同tab里操作的進度,比如說填寫的表單信息,或者已經(jīng)查詢好的數(shù)據(jù)列表等。
那么我們要怎么緩存組件呢?
只需要用到vue中的keep-alive組件

3.1 keep-alive

  • <keep-alive>是Vue的內(nèi)置組件,能在組件切換過程中將狀態(tài)保留在內(nèi)存中,防止重復(fù)渲染DOM。
  • <keep-alive> 包裹動態(tài)組件時,會緩存不活動的組件實例,而不是銷毀它們。
  • <keep-alive><transition>相似,只是一個抽象組件,它不會在DOM樹中渲染(真實或者虛擬都不會),也不在父組件鏈中存在,比如:你永遠在 this.$parent 中找不到 keep-alive 。
注:不能使用keep-alive來緩存固定組件,會無效
//無效
<keep-alive>
 <my-component></my-component>
</keep-alive>

3.2 使用

3.2.1 老版本vue 2.1之前的使用

<keep-alive>
  <router-view v-if="$route.meta.keepAlive"></router-view>
</keep-alive>
<router-view v-if="!$route.meta.keepAlive"></router-view>

需要在路由信息里面設(shè)置router的元信息meta

export default new Router({
 routes: [
  {
   path: '/a',
   name: 'A',
   component: A,
   meta: {
    keepAlive: false // 不需要緩存
   }
  },
  {
   path: '/b',
   name: 'B',
   component: B,
   meta: {
    keepAlive: true // 需要被緩存
   }
  }
 ]
})

3.2.2 比較新而且簡單的用法

直接緩存所有組件/路由

<keep-alive>
  <router-view/>
</keep-alive>

<keep-alive>
  <component :is="view"></component>
</keep-alive>

使用include來處理需要緩存的組件/路由

include有幾種用法,可以是數(shù)組,字符串用標點隔開,也可以是正則,使用正則的時候需要使用v-bind來綁定。
<keep-alive include="['a','b']">//緩存name為a,b的組件
<keep-alive include ="a,b">//緩存name為a,b的組件
<keep-alive :include="/^store/">//緩存name以store開頭的組件
  <router-view/>//可以為router-view
  <component :is="view"></component>//也可以是動態(tài)組件
</keep-alive>

使用exclude來排除不需要緩存的路由

include正好相反,在exclude里的組件不會被緩存。用法類似,不作贅述

3.2.3 一種比較奇怪的情況

當頁面跳轉(zhuǎn)方式有A->CB->C兩種,但是我們從A到C的時候,不需要緩存,從B到C的時候需要緩存。這時候就要用到路由的鉤子結(jié)合老版本用法來實現(xiàn)了。

export default {
 data() {
  return {};
 },
 methods: {},
 beforeRouteLeave(to, from, next) {
  to.meta.keepAlive = false; // 讓下一頁不緩存
  next();
 }
};
export default {
 data() {
  return {};
 },
 methods: {},
 beforeRouteLeave(to, from, next) {
  // 設(shè)置下一個路由的 meta
  to.meta.keepAlive = true; //下一頁緩存
  next();
 }
};

3.3 緩存組件的生命周期函數(shù)

緩存組件第一次打開的時候,和普通組件一樣,也需要執(zhí)行created, mounted等函數(shù)。
但是在被再次激活被停用時,這幾個普通組件的生命周期函數(shù)都不會執(zhí)行,會執(zhí)行兩個比較獨特的生命周期函數(shù)。

activated
這個會在緩存的組件重新激活時調(diào)用

deactivated
這個會在緩存的組件停用時調(diào)用

結(jié)語

這個是很基礎(chǔ)的知識,放在筆記里很久了,不過之前記得有點亂,今天拿出來抖一下塵~

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

文章題目:vueTab切換以及緩存頁面處理的幾種方式
當前路徑:http://aaarwkj.com/article38/gjojpp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)App開發(fā)、網(wǎng)站改版關(guān)鍵詞優(yōu)化、云服務(wù)器、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁設(shè)計公司
国产免费播放一区二区三区| 蜜臀视频一区二区在线播放| 欧美一区二区三区爽| 国产产品在线免费看91| 亚洲一区二区三区欧美精品| 日韩欧美国产精品专区| 国产av不卡精品影片| 国产传媒剧情剧资源网站| 亚洲精品日本一区二区| 久久精品国产一区二区三区91 | 国产剧情av在线资源| 亚洲国产精品成人久久66| 国产高清视频成人在线观看 | 蜜桃免费观看在线视频| 欧美亚洲中文字幕高清| 亚洲精品中文字幕码专区| 九九九热精品在线视频观看| 亚洲国产精品一区二区三区在线| 久久亚洲春色中文字幕| 国产亚洲精品女人久久久| 麻豆精东传媒一区二区| 视频久久这里只有精品| 欧美另类精品一区二区| 亚洲二区中文字幕在线观看| 国产高清在线a视频大全| 国产一级av在线播放| 国产乱国产乱老熟女视频| 亚洲女人天堂av在线| 中文字幕在线感觉av| 91午夜福利国产在线观看| 午夜理论片在线观看有码| 国产精品自拍av一区二区| 欧美日韩亚洲综合国产人| 亚洲中少妇久久中文字幕| 色婷婷一区二区三区影片| 成人午夜激情在线观看| 热久久视频这里只有精品| 97久久精品国产成人影院| 国产成人综合亚洲国产| 国产日韩欧美亚洲一区二区| 四虎官网免费在线观看|