Using nuxt, how do I put the route name in the pag

2019-07-09 21:44发布

I want to set the page title to a different value for each page.

In regular Vue.js, I have done the following:

import router from './router'
import { store } from './store/store';

router.beforeEach((to, from, next) => {
    store.mutations.setRoute(to);
    document.title = store.getters.pageTitle;
    next();
}

How would I get that effect in nuxt?

That is, on both initial page load and when changing pages, I want the browser tab's title to change. For instance, from "My App - About" to "My App - Profile".

2条回答
霸刀☆藐视天下
2楼-- · 2019-07-09 22:29

from nuxt docs, in each pages component you can define the head function that returns the title of page i.e.

head() {
    return {
      title: "About page"
    };
  }
查看更多
贪生不怕死
3楼-- · 2019-07-09 22:40

I found a way to do this, but I don't know if it is the "right" way. I use the mounted() function in default.vue for the initial page load and the transition property in nuxt.config.js for each page change. So, in default.vue:

...mapGetters(['appTitle']),
...mapMutations(['setRoute']),
mounted() {
    this.setRoute(this.$route.name);
    document.title = this.appTitle();
}

And in nuxt.config.js:

transition: {
    name: 'page',
    mode: 'out-in',
    beforeEnter (el) {
        this.$store.commit("setRoute", this.$route.name);
        document.title = this.$store.getters.appTitle;
    }
},
查看更多
登录 后发表回答