Vue動態修改網頁標題
阿新 • • 發佈:2019-06-08
業務需求,進入頁面的時候,網頁有個預設標題,載入的網頁內容不同時,標題需要變更. 例:功能授權,功能授權(張三).
Vue下有很多的方式去修改網頁標題,這裡總結下解決此問題的幾種方案:
一、最笨方案
結合業務直接在Vue生命週期函式 created 和 mounted 中,給 document.title賦值。
- <script>
- import axios from 'axios'
- export default {
- created () {
- document.title = '功能授權'
- },
- mounted() {
- axios.get('***').then((d)=>{
- document.title = '功能授權('+ d.Name + ')'
- })
- }
- }
- </script>
二、普通方案,使用Vue-Router的beforeEach攔截
專案中使用了Vue Router,在路由檔案 index.js 中給需要的路由新增 title。
- routes: [{
- path: '/',
- name: 'home',
- component: () => import('@/pages/home/index'),
- meta:{
- keepAlive: true
- }
- },
- {
- path: '/person/auth,
- name: 'personAuth',
- component: () => import('@/pages/person/auth),
- meta:{
- title: '功能授權',
- keepAlive: false
- }
- }
- ]
在路由的beforeEach 攔截器裡處理
- router.beforeEach((to, from, next) => {
- /* 路由發生變化修改頁面title */
- if (to.meta.title) {
- document.title = to.meta.title
- }
- })
如果想在頁面上依據載入的內容不同再變更title時,請參考方式一的 mounted函式處理邏輯.
三、優雅方案,使用Vue 自定義指令(directive)
如前文所提,頁面獲取不同資料狀態時,需要展示不同的標題。那麼我們可以結合vue 自定義指令(directive)可更優雅的處理網頁標題的動態更新。
自定義指令 v-web-title的定義
- export default {
- inserted: function (el, binding) {
- const { value } = binding
- if (el.dataset.title) { // 方式1,可以給標籤的data-title的屬性賦值
- document.title = el.dataset.title
- } else if (value && value.title) { // 方式2,指令傳參
- document.title = value.title
- }
- },
- update (el, binding, vnode, oldVnode) {
- const { value } = binding
- if (el.dataset.title) {
- document.title = el.dataset.title
- } else if (value && value.title) {
- document.title = value.title
- }
- }
- }
在頁面上使用v-web-title有兩種方式
1.給標籤 data-title屬性賦值
- <template>
- <div v-web-title
- :data-title="textTitle">
- </template>
- <script>
- import axios from 'axios'
- export default {
- data(){
- return {
- textTitle:'功能授權'
- }
- },
- mounted () {
- axios.get('***').then((d) => {
- this.textTitle = '功能授權(' + d.Name + ')'
- })
- }
- }
- </script>
2.給指令傳參
- <template>
- <div v-web-title="{title:textTitle}">
- </template>
- <script>
- import axios from 'axios'
- export default {
- data(){
- return {
- textTitle:'功能授權'
- }
- },
- mounted () {
- axios.get('***').then((d) => {
- this.textTitle = '功能授權(' + d.Name + ')'
- })
- }
- }
- </script>
四、參考
1. vue單頁面應用中動態修改title 主要介紹使用vue-weachat-title 元件
2.vue.js自定義指令詳解 主要介紹自定義指令的鉤子函式,以及指令傳