欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue router 通過(guò)路由來(lái)實(shí)現(xiàn)切換頭部標(biāo)題功能

 更新時(shí)間:2019年04月24日 11:08:41   作者:破殼而出的蝌蚪  
在做單頁(yè)面應(yīng)用程序時(shí),一般頁(yè)面布局頭尾兩塊都是固定在布局頁(yè)面,中間為是路由入口。這篇文章主要介紹了vue-router 通過(guò)路由來(lái)實(shí)現(xiàn)切換頭部標(biāo)題 ,需要的朋友可以參考下

在做單頁(yè)面應(yīng)用程序時(shí),一般頁(yè)面布局頭尾兩塊都是固定在布局頁(yè)面,中間為是路由入口。這時(shí)訪問(wèn)頁(yè)面時(shí)頭部標(biāo)題不會(huì)變,該問(wèn)題的解決方案如下:

通過(guò)采用組件內(nèi)路由衛(wèi)士(beforeRouterEnter、beforeRouterUpdate)與路由元信息(meta) 來(lái)實(shí)現(xiàn)更新頭部標(biāo)題信息。點(diǎn)擊查看文檔

beforeRouterEnter:第一次進(jìn)入時(shí)調(diào)用。

beforeRouterUpdate:重復(fù)使用當(dāng)前組件時(shí)調(diào)用。

效果圖如下:

注意看頁(yè)面標(biāo)題與圖標(biāo)變換

 路由元信息(meta)配置

在路由元信息中配置頁(yè)面標(biāo)題,通過(guò)組件內(nèi)路由衛(wèi)士獲取

const router = new Router({
  mode: 'history',
  base: process.env.BASE_URL,
  routes: [
    {
      path: "help",
      name: "help",
      meta: {
        title: "新手幫助"
      },
      component: () => import('./views/Help.vue')
    },
    {
      path: "page",
      name: "page",
      meta: {
        title: "寶貝信息"
      },
      component: () => import('./views/Page.vue')
    }
  ]
})

路由布局頁(yè)面

 header 與 footer 是固定頭尾, main為路由入口。 title為頁(yè)面標(biāo)題

<template>
  <div id="app">
    <header class="header">
      <button @click="back" class="t-xiaoxi iconfont" v-html="icon"></button>
      <h1 class="t-title">{{title}}</h1>
      <router-link to="/search" class="t-sousuo iconfont">&#xe611;</router-link>
    </header>
    <div class="main">
      <router-view></router-view>
    </div>
    <footer class="footer">
      // ...
    </footer>
  </div>
</template>

在beforeRouteEnter、beforeRouteUpdate函數(shù)中獲取路由元信息,并更新頁(yè)面標(biāo)題。

beforeRouteEnter:當(dāng)?shù)谝淮芜M(jìn)入時(shí),會(huì)被標(biāo)題進(jìn)行一次初始化操作

beforeRouteUpdate:當(dāng)組件被重復(fù)調(diào)用時(shí),執(zhí)行更新操作。

<script>
  export default {
    name: "app",
    data() {
      return {
        title: "我的網(wǎng)站",
        url: '/',
        icon: '&#xe627;'
      }
    },
    methods: {
      back() {
        this.$router.go(this.url);
      },
      update(route) {
        [this.title, this.url, this.icon] = ["我的網(wǎng)站", '/', '&#xe627;'];
        if (!['', '/'].includes(route.path)) { // 判斷是否根頁(yè)面,用于切換標(biāo)題與返回上一頁(yè)或回到主頁(yè)
          [this.title, this.url, this.icon] = [route.meta.title || "", '-1', '&#xe81e;'];
        }
      }
    },
    beforeRouteEnter(to, from, next) {
      next(vm => { //回調(diào)函數(shù),此時(shí)this指針不可用,可采用回調(diào)函數(shù)訪問(wèn)。
        vm.update(to);
      })
    },
    beforeRouteUpdate(to, from, next) {
      this.update(to);
      next();
    }
  };
</script>

總結(jié)

以上所述是小編給大家介紹的vue router 通過(guò)路由來(lái)實(shí)現(xiàn)切換頭部標(biāo)題功能,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • Vue3利用自定義ref實(shí)現(xiàn)防抖功能

    Vue3利用自定義ref實(shí)現(xiàn)防抖功能

    在Vue3中,ref提供了訪問(wèn)組件內(nèi)DOM元素和子組件實(shí)例的方法,防抖是一種限制函數(shù)調(diào)用頻率的方法,即在一定時(shí)間內(nèi)多次觸發(fā)同一個(gè)函數(shù),只執(zhí)行最后一次觸發(fā)的函數(shù),本文將給大家介紹了Vue3如何利用自定義ref實(shí)現(xiàn)防抖,需要的朋友可以參考下
    2024-05-05
  • Vue-cli 使用json server在本地模擬請(qǐng)求數(shù)據(jù)的示例代碼

    Vue-cli 使用json server在本地模擬請(qǐng)求數(shù)據(jù)的示例代碼

    本篇文章主要介紹了Vue-cli 使用json server在本地模擬請(qǐng)求數(shù)據(jù)的示例代碼,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2017-11-11
  • 前端使用print.js實(shí)現(xiàn)打印功能(基于vue)

    前端使用print.js實(shí)現(xiàn)打印功能(基于vue)

    最近新接了一個(gè)需求,想要在前端實(shí)現(xiàn)打印功能,下面這篇文章主要給大家介紹了關(guān)于前端使用print.js實(shí)現(xiàn)打印功能(基于vue)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • 關(guān)于Element-UI中slot的用法及說(shuō)明

    關(guān)于Element-UI中slot的用法及說(shuō)明

    這篇文章主要介紹了關(guān)于Element-UI中slot的用法及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue 微信端掃描二維碼蘋果端卻只能保存圖片問(wèn)題(解決方法)

    Vue 微信端掃描二維碼蘋果端卻只能保存圖片問(wèn)題(解決方法)

    這幾天在做項(xiàng)目時(shí)遇到微信掃描二維碼的然后進(jìn)入公眾號(hào)網(wǎng)頁(yè)巴拉巴拉的,然后就很順利的遇到了在安卓端掃碼的時(shí)候,順利的一塌糊涂,然后到了蘋果端的時(shí)候,就只能出現(xiàn)一個(gè)保存圖片,然后就寫(xiě)一下記錄一下這問(wèn)題的解決方法
    2020-01-01
  • electron-builder打包vue2項(xiàng)目問(wèn)題總結(jié)

    electron-builder打包vue2項(xiàng)目問(wèn)題總結(jié)

    這篇文章主要介紹了electron-builder打包vue2項(xiàng)目問(wèn)題總結(jié),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2024-08-08
  • Vue收集依賴與觸發(fā)依賴源碼刨析

    Vue收集依賴與觸發(fā)依賴源碼刨析

    vue對(duì)依賴的管理使用的是發(fā)布訂閱者模式,其中watcher扮演訂閱者,Dep扮演發(fā)布者。所以dep中會(huì)有多個(gè)watcher,一個(gè)訂閱者也可以有多個(gè)發(fā)布者(依賴)??偣踩齻€(gè)過(guò)程:定義依賴、收集依賴、觸發(fā)依賴。下面開(kāi)始詳細(xì)講解三個(gè)過(guò)程
    2022-10-10
  • 解決vue中使用swiper 插件出錯(cuò)的問(wèn)題

    解決vue中使用swiper 插件出錯(cuò)的問(wèn)題

    這篇文章主要介紹了vue中使用swiper 插件出錯(cuò)問(wèn)題及解決辦法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08
  • vue3.0中setup的兩種用法實(shí)例

    vue3.0中setup的兩種用法實(shí)例

    setup函數(shù)是一個(gè)新的組件選項(xiàng),作為在組件內(nèi)使用Composition Api的入口點(diǎn),下面這篇文章主要給大家介紹了關(guān)于vue3.0中setup的兩種用法,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-09-09
  • 詳解Vue項(xiàng)目的打包方式(生成dist文件)

    詳解Vue項(xiàng)目的打包方式(生成dist文件)

    本文主要介紹了詳解Vue項(xiàng)目的打包方式(生成dist文件),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01

最新評(píng)論