zoukankan      html  css  js  c++  java
  • [Nuxt] Navigate with nuxt-link and Customize isClient Behavior in Nuxt and Vue.js

    Because Nuxt renders pages on the server, you should use the nuxt-link components to navigate between pages. Each time a page loads, you can check if you're on the client or server and avoid doing unnecessary loading based on how the page was rendered. This lesson walks you through using nuxt-link and isClient to navigate and avoid reloading data.

    'fetch' can do server side rendering:

     async fetch ({store, redirect, error}) {
    try {
        const res = await axios.get('https://todos-cuvsmolowg.now.sh/todos')
        store.commit('init', res.data)
      } catch (err) {
        redirect('/error')
      }
    }

    Once it successfully store the data inside the store object, we don't need to fetch it again.

    To avoid refetching the data, we can use 'isClient' from the context.

    async fetch ({store, redirect, error, isClient}) {
      if (isClient) {
        return
      }
      try {
        const res = await axios.get('https://todos-cuvsmolowg.now.sh/todos')
        store.commit('init', res.data)
      } catch (err) {
        redirect('/error')
      }
    }

    Because this fetch method can be reused in elsewhere, so we can make it a sprated file:

    shared.js:

    import axios from 'axios'
    
    export async function init ({store, redirect, error, isClient}) {
      if (isClient) {
        return
      }
      try {
        const res = await axios.get('https://todos-cuvsmolowg.now.sh/todos')
        store.commit('init', res.data)
      } catch (err) {
        redirect('/error')
      }
    }

    Required it in side page:

    <template>
      <div>
        <nuxt-link to="/computed">Computed</nuxt-link>
        <article class="pa3 pa5-ns">
          <ul class="list pl0 ml0 center mw6 ba b--light-silver br2">
            <li v-for="todo of todos" class="ph3 pv3 bb b--light-silver">{{todo.task}}</li>
          </ul>
        </article>
      </div>
    </template>
    
    <script>
      import { mapState } from 'vuex'
      import {init} from './shared'
    
      export default {
    
        fetch: init,
        computed: {
          ...mapState({
            todos: (state) => state.todos
          })
        }
      }
    </script>

    Here we use 'nuxt-link' to the navigation.

    Computed page should not load the todos again, since we already have the data store in the store object.

    computed.vue:

    <template>
      <div>
        <nuxt-link to="/">Home</nuxt-link>
        <article class="pa3 pa5-ns">
          <ul class="list pl0 ml0 center mw6 ba b--light-silver br2">
            <li v-for="todo of todos" class="ph3 pv3 bb b--light-silver">{{todo.task}}</li>
          </ul>
        </article>
      </div>
    </template>
    
    <script>
      import { mapState } from 'vuex'
      import {init} from './shared'
    
      export default {
    
        fetch: init,
        computed: {
          ...mapState({
            todos: (state) => state.todos
          })
        }
      }
    </script>
  • 相关阅读:
    ghost版本xp安装iis的问题
    装vs2005 sp1出现数字签名错误的解决办法
    FLEX对整个截屏或单个UI进行截图
    在Apache环境下成功的运行ASP.NET
    向园子的高手们求救 关于45斜视地图的寻路
    第一次在博客里面写东西
    在 Linux 下运行 ASP.NET 2.0
    sql left join inner jion 区别
    C# 图片识别(支持21种语言)
    5、Java并发编程:Lock
  • 原文地址:https://www.cnblogs.com/Answer1215/p/7230822.html
Copyright © 2011-2022 走看看